728x90
반응형
SMALL
📌 문제 정보
- 출처: 문제 링크
- 난이도: ⭐
- 문제 유형: 조건문
- 사용 언어: Java
🔍 문제 설명
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
💡 풀이 노트
A = B+C >=60 ? A+(B+C)/60 : A;
A = A%24;
B = (B+C)%60;
1. 첫 번째 라인 (`A = B + C >= 60 ? A + (B + C) / 60 : A`)
- `B + C >= 60` → 분(B) + 추가된 분(C)이 60 이상이면, 시간이 증가
- `(B + C) / 60` → 추가된 시간이 몇 시간인지 계산
- `A + (B + C) / 60` → 시간(A)에 추가된 시간을 더함
- `B + C < 60`이면 시간(A)은 그대로 유지
2. 두 번쨰 라인(`A = A % 24`)
- 24시간 형식 유지 → A가 24 이상이면 다시 0부터 시작하도록 변환
3. 세 번째 라인 (`B = (B + C) % 60`)
- 분(B)은 0~59까지만 표현 가능 → 60분이 넘어가면 0부터 다시 시작하도록 변환
🚀 코드 (Java)
import java.util.*;
import java.io.*;
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 A = Integer.parseInt(st.nextToken());
int B = Integer.parseInt(st.nextToken());
int C = Integer.parseInt(br.readLine());
A = B+C >=60 ? A+(B+C)/60 : A;
A = A%24;
B = (B+C)%60;
System.out.println(A +" " + B);
}
}
🖥 실행 결과
입력: 14 30 출력: 14 50
20
입력: 17 40 출력: 19 0
80
입력: 23 48 출력: 0 13
25
📌 깃허브 코드 저장소: https://github.com/glorypang/CodingTest
728x90
반응형
LIST