본문 바로가기
Algorithm

[BAEKJOON_1085] 직사각형에서 탈출(Python)

by ZZANG BAE 2022. 7. 21.

*출처

https://www.acmicpc.net/problem/1085

 

1085번: 직사각형에서 탈출

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

www.acmicpc.net

[문제]

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

[생각]

  • 한수의 위치에서 가장 가까운 모서리를 찾아야함
  • 한수의 좌표(x,y)와 오른쪽 모서리로부터의 거리(w-x), 왼쪽 모서리로부터의 거리(h-y)
  • x, y, w-x, h-y 중에 제일 작은 값을 출력하도록 함

[코드]

x, y, w, h = map(int,input().split())

df_x = w - x
df_y = h - y

li_asce = [x, y, df_x, df_y]    #list로 만듦
li_asce.sort()  #오름차순으로 정렬
print(li_asce[0])

[공부한 점]

  • input() 데이터는 str로 반환한다.
  • input()로 여러 개의 데이터를 받을 때, int(input().split()) 하면 오류가 뜬다. list로 저장됨
    • 따라서 map 함수를 적용해야한다.
    • TypeError: int() argument must be a string, a bytes-like object or a number, not 'list'
    • list 로 저장해놓는다(오류 메시지)

'Algorithm' 카테고리의 다른 글

[BAEKJOON_1550] 16진수(Python)  (0) 2022.08.02
[BAEKJOON_2061] 좋은 암호  (0) 2022.08.01
[BAEKJOON_1076] 저항(Python)  (0) 2022.07.31
[BAEKJOON_1009] 분산 처리(Python)  (0) 2022.07.30
[BAEKJOON_1267] 핸드폰 요금(Python)  (0) 2022.07.29