반응형
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞은 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 2706 | 1013 | 932 | 39.308% |
문제
창영마을에서 정인이의 반란은 실패로 끝났다. (3028번)
테러리스트로 변신한 정인이는 창영마을에 경고를 하려고 한다.
사실 정인이는 창영마을에서 제일 착한사람이다. 따라서, 사람들을 다치지 않게하려고 한다.
유튜브에서 폭발에 대한 동영상을 찾아보다가, 그는 나트륨을 물에 던지면 폭발한다는 사실을 알게 되었다.
정인이는 창영마을의 중심을 지나는 "강산강" 근처에 숨어있다가, 나트륨을 위의 동영상처럼 물에 던질 것이다.
현재 시간과 정인이가 나트륨을 던질 시간이 주어졌을 때, 정인이가 얼마나 숨어있어야 하는지 구하는 프로그램을 작성하시오. (정인이는 적어도 1초를 기다리며, 많아야 24시간을 기다린다.)
입력
첫째 줄에 현재 시간이 hh:mm:ss 형식으로 주어진다. (시, 분, 초) hh는 0보다 크거나 같고, 23보다 작거나 같으며, 분과 초는 0보다 크거나 같고, 59보다 작거나 같다.
둘째 줄에는 나트륨을 던질 시간이 위와 같은 형식으로 주어진다.
출력
첫째 줄에 정인이가 기다려야 하는 시간을 입력과 같은 형식으로 출력한다.
예제 입력 1
20:00:00
04:00:00
예제 출력 1
08:00:00
코드
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
public class p3029 {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
SimpleDateFormat format = new SimpleDateFormat("HH:mm:ss");
format.setTimeZone(TimeZone.getTimeZone("GMT"));
String time1 = sc.next();
String time2 = sc.next();
try {
Date date1 = format.parse(time1);
Date date2 = format.parse(time2);
long gap = date2.getTime() - date1.getTime();
if(gap == 0){
System.out.println("24:00:00");
} else {
System.out.println(format.format(gap));
}
} catch (ParseException e) {
e.printStackTrace();
}
}
}
더 좋은 풀이
import java.util.Scanner;
public class Main {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String curTime = sc.next();
String natriumThrowingTime = sc.next();
sc.close();
if (curTime.equals(natriumThrowingTime)) {
System.out.print("24:00:00");
System.exit(0);
}
int h = Integer.parseInt(natriumThrowingTime.split(":")[0]) - Integer.parseInt(curTime.split(":")[0]);
int m = Integer.parseInt(natriumThrowingTime.split(":")[1]) - Integer.parseInt(curTime.split(":")[1]);
int s = Integer.parseInt(natriumThrowingTime.split(":")[2]) - Integer.parseInt(curTime.split(":")[2]);
if (s < 0) {
s += 60;
--m;
}
if (m < 0) {
m += 60;
--h;
}
if (h < 0) {
h += 24;
}
System.out.format("%02d:%02d:%02d", h, m, s);
}
}
반응형
'알고리즘 > [ Baekjoon ]' 카테고리의 다른 글
[ BOJ ][JAVA][4358] 생태학 (0) | 2021.04.25 |
---|---|
[ BOJ ][JAVA][3687] 성냥개비 (0) | 2021.04.25 |
[ BOJ ][JAVA][2961] 도영이가 만든 맛있는 음식 (0) | 2021.04.25 |
[ BOJ ][JAVA][2941] 크로아티아 알파벳 (0) | 2021.04.25 |
[ BOJ ][JAVA][1786] 찾기 (0) | 2021.04.25 |