- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 알고리즘
- 구글 로그인
- 배열
- C++
- 정렬
- 공유대학
- 안드로이드 스튜디오
- 비주얼 베이직
- 프로그래머스
- python
- android studio
- 파이썬
- C언어
- 프로그래밍 입문
- Firebase
- 백준
- til
- 연결리스트
- 로그인
- Java
- 코딩테스트
- oauth
- 자바
- 동적할당
- 컴퓨터공학과
- firebase google
- sql
- 자료구조
- 안드로이드
Archives
코딩하는 해달이
[백 준 Java] 1085번 문제 : 직사각형에서 탈출 본문
문제 설명
한수는 지금 (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는 정수
알고리즘
푼 방법
직사각형의 길이와 높이를 한수의 좌표와 비교해서 더 가까운 거리를 출력한다.
풀이코드
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.BufferedReader;
import java.util.ArrayList;
import java.util.List;
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 shorts_x;
int shorts_y;
int x = Integer.parseInt(st.nextToken());
int y = Integer.parseInt(st.nextToken());
int w = Integer.parseInt(st.nextToken());
int h = Integer.parseInt(st.nextToken());
if(x > w/2) {
shorts_x = w - x;
} else {
shorts_x = x;
}
if(y > h/2) {
shorts_y = h - y;
} else {
shorts_y = y;
}
if (shorts_x > shorts_y) {
System.out.println(shorts_y);
} else {
System.out.println(shorts_x);
}
}
}
링크
https://www.acmicpc.net/problem/1085
반응형
'개인 공부 > 백준' 카테고리의 다른 글
[백 준 Java] 1027번 문제 : 고층 건물 (0) | 2023.03.01 |
---|---|
[백 준 Java] 1016번 문제 : 제곱 ㄴㄴ수 (0) | 2023.02.27 |
[백 준 Java] 1004번 문제 : 어린 왕자 (0) | 2023.02.25 |
[백 준 Java] 1003번 문제 : 피보나치 함수 (0) | 2023.02.24 |
[백 준 Java] 1075번 문제 : 나누기 (0) | 2023.02.23 |
Comments