백준 - 인공지능 시계 2530번 [1일차]
시간 제한 | 메모리 제한 |
1 초 | 512 MB |
문제
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 초 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 초 단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
입력
첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23), 분 B (0 ≤ B ≤ 59)와 초 C (0 ≤ C ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 D (0 ≤ D ≤ 500,000)가 초 단위로 주어진다.
출력
첫째 줄에 종료되는 시각의 시, 분, 초을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수이며, 분, 초는 0부터 59까지의 정수이다. 디지털 시계는 23시 59분 59초에서 1초가 지나면 0시 0분 0초가 된다.)
나의코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Solution3 {
public static void main(String[] args) throws IOException {
// 시작시간 입력받음
// StringTokenizer 로 잘라서 현재 시간 구하기
// 첫번째 = 0 < HH < 23
// 두번째 = 0 < MM < 59
// 세번째 = 0 < SS < 59
// 23시 29분 29초 오버시 0 0 0으로 변함
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
// 첫번재 줄
StringTokenizer st = new StringTokenizer(br.readLine());
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
int c = Integer.parseInt(st.nextToken());
int d = Integer.parseInt(br.readLine());
//1분은 60초 - d에 입력받은 값을 더해줌
b += d/60;
c += d%60;
//60초가 넘는 시간대를 분으로 올려줌
b += c/60;
c = c%60;
//60분이 넘는 시간대를 시간으로 올려줌
a += b/60;
b = b%60;
a = a%24;
System.out.printf("%d\t%d\t%d",a,b,c);
}
}
처음에는
입력받은 숫자를 시/분/초 로 바꿔서 연산했는데,
초로 받은 숫자를 바로 연산 작업을 진행할수 있었다!
'Algorithm > 코딩테스트' 카테고리의 다른 글
[코딩테스트] 백준 - 주사위 세개 (0) | 2024.07.17 |
---|---|
[코딩테스트] 백준 - 나머지 (0) | 2024.07.17 |
[코딩테스트] 백준 - 검증수 (0) | 2024.07.17 |
[코딩테스트] 백준 - 두 수 비교하기 (0) | 2024.07.17 |
[코딩테스트] 코팅테스트 - 힙(Heap) 더 맵게 (0) | 2024.06.10 |