문제
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
입력
첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다.
출력
첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)
문제 풀이
이 문제는 조건문을 굉장히 많이 썼다. 즉, 신경 써야할 조건들이 매우 많았다.
우선 코드를 보면서 설명하겠다.
import java.util.Scanner;
public class Main {
public static void solution() {
Scanner scanner = new Scanner(System.in);
int hours = scanner.nextInt();
int minutes = scanner.nextInt();
int times = scanner.nextInt();
int answerHours = 0;
int answerMinutes = 0;
// 경우 1. 정각 이전일 때
if (minutes + times < 60) {
answerHours = hours;
answerMinutes = minutes + times;
}
// 경우 2. 정각일 때
else if ((minutes + times) % 60 == 0) {
answerHours = hours + (minutes + times) / 60;
answerMinutes = 0;
if (answerHours == 24) {
answerHours = 0;
}
}
// 경우 3. 정각 이후일 때
else if (minutes + times > 60) {
answerHours = hours + (minutes + times) / 60;
answerMinutes = (minutes + times) - ((minutes + times) / 60 * 60);
if (answerHours >= 24) {
answerHours = answerHours - 24;
}
}
System.out.println(answerHours + " " + answerMinutes);
}
public static void main(String[] args) {
solution();
}
}
조건을 크게 3가지로 나눴다.
경우 1. 정각 이전일 때
경우 2. 정각일 때
경우 3. 정각 이후일 때
정각 이전일 때에는 큰 로직 없이 단순히 minutes + times
만 계산해줬다.
그리고 경우 2(정각일 때)부터 로직이 들어가게 되는데,answerHours
의 값은 hours + (minutes + times) / 60;
으로 구했다.
그리고 나서 정각이기 때문에 answerMinutes
는 당연히 0이 된다.
또한 answerHours
가 24일 경우(자정일 경우)에는 answerHours
도 0이 된다.
마지막으로 경우 3(정각 이후일 때)에서는 비교적 복잡한 로직이 들어갔다.answerHours
는 경우 2와 똑같이 구해주고, 분을 구하는 부분에서 상당히 어려움을 겪었다.
예를 들어 결과값이 72분이 나왔다면 이를 60으로 빼야하고, 121분이 나왔다면 120으로 빼야한다.
여기에서 나는 각각 60과 120을 어떻게 구해야하는지 오랫동안 생각을 해봤다.
그 결과 72일 경우에는 72 / 60 * 60 의 공식을 쓰면 된다는 사실을 알게 되었고,
121일 경우에는 121 / 60 * 60 의 공식을 쓰면 됐다.
그래서 (minutes + times) - ((minutes + times) / 60 * 60);
의 결과를 도출해냈다.
마지막으로 answerHours
가 24이상일 때의 경우도 생각했다.
맨 처음에는 단순히 answerHours = 0
이라고 작성했고, 예시 입력을 모두 해본 결과 문제가 없었다.
하지만 제출에 실패했고, 테스트케이스를 돌린 결과 틀린 부분이 있었다.
그래서 answerHours = answerHours - 24;
로 수정하게 되었다.
이번 문제 자체는 그렇게 어렵진 않았지만, 조건들이 상당히 까다로웠다.
내가 생각했던 것보다 고려해야할 조건들이 엄청 많진 않았음에도 불구하고 구현하는데 시간을 꽤 썼다.
'PROBLEM SOLVING' 카테고리의 다른 글
[백준] 문자열 (1) | 2025.04.18 |
---|---|
[백준] 단어 길이 재기 (0) | 2025.04.18 |
[백준] 문자와 문자열 (0) | 2025.04.18 |
[프로그래머스] 삼각형의 완성조건 (2) (0) | 2025.04.18 |
[프로그래머스] 암호해독 (0) | 2025.04.18 |