본문 바로가기
Algorithm/백준 알고리즘

BOJ(1085) - Kotlin

by 클리마 2022. 8. 16.
728x90

문제

한수는 지금 (x, y)에 있다. 직사각형은 각 변이 좌표축에 평행하고, 왼쪽 아래 꼭짓점은 (0, 0), 오른쪽 위 꼭짓점은 (w, h)에 있다. 직사각형의 경계선까지 가는 거리의 최솟값을 구하는 프로그램을 작성하시오.

입력

첫째 줄에 x, y, w, h가 주어진다.

출력

첫째 줄에 문제의 정답을 출력한다.

제한

  • 1 ≤ w, h ≤ 1,000
  • 1 ≤ x ≤ w-1
  • 1 ≤ y ≤ h-1
  • x, y, w, h는 정수

 

나의 접근방법

(x,y)가 왼쪽(x-0)이나 오른쪽(w-x)에 가까운지 혹은 아래쪽(y-0)이나 위쪽(h-y)에 가까운지를 보고 최솟값을 출력하도록 했다.

 

코드

/* 직사각형에서 탈출 */

import java.lang.Integer.min
import java.util.Scanner

fun main() = with(Scanner(System.`in`)) {
    val x = nextInt()
    val y = nextInt()
    val w = nextInt()
    val h = nextInt()

    val distanceX = min(x-0, w-x)
    val distanceY = min(y-0, h-y)

    print(min(distanceX, distanceY))
}
728x90

'Algorithm > 백준 알고리즘' 카테고리의 다른 글

BOJ(16466) - Kotlin  (0) 2022.06.13
BOJ(12605) - Kotlin  (0) 2022.06.12
BOJ(17608) - Kotlin  (0) 2022.06.10
BOJ(10104) - Kotlin  (0) 2022.06.09
BOJ(2605) - Kotlin  (0) 2022.06.07