일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- 백준
- 파이썬
- Java
- 최단 경로
- 페이코 추천인
- php 프로그래밍 입문
- programmers
- php 프로그래밍 입문 예제
- php 프로그래밍 입문 3판
- C
- SWEA
- 스프링
- 배열
- 플러터 개발환경 설정
- php 프로그래밍 입문 연습문제
- spring
- 한정 분기
- Flutter
- php 프로그래밍 입문 솔루션
- 자바 스프링
- 플러터
- php 프로그래밍 입문 문제풀이
- 페이코 초대코드
- 페이코 친구코드
- 자바
- JAVA SPRING
- php 프로그래밍
- 페이코 추천인코드
- php
- C언어
Archives
- Today
- Total
03-16 00:01
ImJay
[SWEA/Java] 8382. 방향 전환 본문
반응형
[SWEA/Java] 8382. 방향 전환
SW Expert Academy
SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!
swexpertacademy.com
해설
풀이
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Solution {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringBuilder sb = new StringBuilder();
// 테스트 케이스의 개수를 입력받음
int testCase = Integer.parseInt(br.readLine());
// 각 테스트 케이스에 대한 반복
for (int t = 1; t <= testCase; t++) {
// 시작점과 끝점의 좌표를 입력받음
String input = br.readLine();
StringTokenizer st = new StringTokenizer(input);
int startX = Integer.parseInt(st.nextToken());
int startY = Integer.parseInt(st.nextToken());
int endX = Integer.parseInt(st.nextToken());
int endY = Integer.parseInt(st.nextToken());
// x축과 y축 각각의 거리를 계산
int distanceX = Math.abs(startX - endX);
int distanceY = Math.abs(startY - endY);
int ans = 0;
// x축 거리가 y축 거리보다 큰 경우
if (distanceX > distanceY) {
ans = distanceX * 2;
// 거리가 짝수일 때, y축 거리가 홀수면 하나 감소
if (distanceX % 2 == 0) {
if (distanceY % 2 == 1) ans--;
}
// 거리가 홀수일 때, y축 거리가 짝수면 하나 감소
else {
if (distanceY % 2 == 0) ans--;
}
}
// y축 거리가 x축 거리보다 큰 경우
else {
ans = distanceY * 2;
// 거리가 짝수일 때, x축 거리가 홀수면 하나 감소
if(distanceY % 2 == 0) {
if (distanceX % 2 == 1) ans--;
}
// 거리가 홀수일 때, x축 거리가 짝수면 하나 감소
else {
if (distanceX % 2 == 0) ans--;
}
}
// 결과를 StringBuilder에 추가
sb.append("#" + t + " " + ans + "\n");
}
// 최종 결과 출력
System.out.print(sb);
}
}
반응형
'SW Expert Academy > D4' 카테고리의 다른 글
[SWEA/Java] 1210. Ladder1 : 재귀로 풀기 (0) | 2024.02.04 |
---|---|
[SWEA/Java] 1249. 보급로 (0) | 2024.02.04 |
[SWEA/Java] 4408. 자기 방으로 돌아가기 (0) | 2024.01.29 |
[SWEA/Java] 1210. [S/W 문제해결 기본] 2일차 - Ladder1 (0) | 2024.01.29 |
[SW Expert Academy] 18799. 평균의 평균 (0) | 2023.11.18 |
Comments