✏️ 문제풀이/백준

[백준/Java] 1085번 :: 직사각형에서 탈출

bono-hye 2024. 5. 3. 22:28

| 문제

한수는 지금 (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는 정수

| 예제 입력

6 2 10 3

 

| 예제 출력

1

 

| 풀이

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;


public class Main
{
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine());
		
		int x = Integer.parseInt(st.nextToken());
		int y = Integer.parseInt(st.nextToken());
		int w = Integer.parseInt(st.nextToken());
		int h = Integer.parseInt(st.nextToken());
		
		int minWidth = (w-x)<x ? (w-x) : x;
		int minHeight = (h-y)<y ? (h-y) : y;
		
		if(minWidth < minHeight)
			System.out.println(minWidth);
		else
			System.out.println(minHeight);	
	}
}

| 정리

가로와 세로에서 각각 최소 거리를 찾기 위해 삼항연산을 활용하고

거기서 얻은 최소 거리를 비교하여 최종 최솟값을 뽑아냈다!