[백준] 1783번: 병든 나이트 - Kotlin[코틀린]

2024. 2. 29. 20:58·알고리즘/Baekjoon

문제

 

 

1783번: 병든 나이트

첫째 줄에 체스판의 세로 길이 N와 가로 길이 M이 주어진다. N과 M은 2,000,000,000보다 작거나 같은 자연수이다.

www.acmicpc.net

 


풀이

 

 병든 나이트는 오른쪽 위나 아래로만 움직일 수 있으며 4칸 이상 방문한 경우에는 모든 방향으로 최소 한 번은 움직여야 하기 때문에 체스판의 크기에 따라 움직임이 제한된다.

 

 - N = 1

   아무 방향으로 움직일 수 없기 때문에 답은 1이다.

 

 - N = 2

   2번과 3번 방향으로만 움직일 수 있기 때문에 답은 (M+1)/2이다. 그러나 최대 4칸까지만 이동이 가능하다.

 

 - N >= 3

   1) M < 7:  1번과 4번 방향을 번갈아가면서 이동하는 것이 최대로 방문하는 방법이다. 따라서 답은 M이다. 그러나 최대 4칸까지만 이동이 가능하다.

   2) M >= 7: 네 방향 모두 움직일 수 있고 답은 M - 2이다. (2번과 3번으로 이동할 때 2칸 이동하기 때문이다.)

 


코드

 

fun main() {
    val br = System.`in`.bufferedReader()
    val bw = System.out.bufferedWriter()

    val (rows, cols) = br.readLine().split(' ').map{ it.toInt() }

    bw.write(
        if (rows == 1) "1"
        else if (rows == 2) "${minOf((cols + 1) / 2, 4)}"
        else {
            if (cols < 7) "${minOf(cols, 4)}"
            else "${cols - 2}"
        }
    )
    bw.flush()
    bw.close()
    br.close()
}

 

'알고리즘 > Baekjoon' 카테고리의 다른 글

[백준] 2210번: 숫자판 점프 - Kotlin[코틀린]  (1) 2024.03.02
[백준] 1914번: 하노이 탑 - Kotlin[코틀린]  (0) 2024.03.01
[백준] 1080번: 행렬 - Kotlin[코틀린]  (0) 2024.02.28
[백준] 1780번: 종이의 개수 - Kotlin[코틀린]  (0) 2024.02.27
[백준] 9205번: 맥주 마시면서 걸어가기 - Kotlin[코틀린]  (0) 2024.02.26
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 2210번: 숫자판 점프 - Kotlin[코틀린]
  • [백준] 1914번: 하노이 탑 - Kotlin[코틀린]
  • [백준] 1080번: 행렬 - Kotlin[코틀린]
  • [백준] 1780번: 종이의 개수 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      우선순위 큐
      그래프이론
      크루스칼
      수학
      투 포인터
      프림
      분할 정복
      에라토스테네스의 체
      그래프 탐색
      MST
      정렬
      브루트포스
      재귀
      스택
      티스토리
      이분 탐색
      문자열
      그리디
      구현
      DP
      누적 합
      BFS
      분리집합
      큐
      모듈러 곱셈 역원
      백트래킹
      소수 판정
      피보나치
      유니온파인드
      dfs
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 1783번: 병든 나이트 - Kotlin[코틀린]
    상단으로

    티스토리툴바