KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
1 초 128 MB 313279 119965 101271 38.101%
문제
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다.
첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)
이번 문제에서 어려웠던 건 쉽게 보이지 않는 예외를 잡아내는 것이었다.
#include <iostream>
using namespace std;
int main()
{
int A,B,C;
int H,M;
cin>>A>>B>>C;
if(B+C<60){
cout<<A<<" "<<B+C;
}else if(A<23 && B+C>=60){
H = A + ((B+C)/60);
M = ((B+C)%60);
cout<<H<<" "<<M;
}else if(A==23){
H = (A + ((B+C)/60))-24;
M=((B+C)%60);
cout<<H<<" "<<M;
}else{return 0;}
return 0;
}
- B+C가 60보다 작을 때는 바로 분으로 표시 되도록 하였다.
- A가 24가 넘어가면 0부터 다시 시작해야 되는 점을 고려해서 조건문을 작성하였다. 오직 23+1 => 0만 생각했던게 너무 좁은 시야 였다
- 이렇게만 작성했을 때도 모든 입력 예제에서 다 올바르게 나왔기 때문에 반례를 찾는 과정이 너무 답답했다..
- 그러다 질문 게시판에서 드디어 틀린 정답이 나오는 경우 발견..!
입력 : 7 20 1000
출력 : 24 0
- 엄청 큰 분이 주어지는 경우를 생각하지 못했다.. 눈치채고 생각해보면 완전 당연한 경우..
#include <iostream>
using namespace std;
int main()
{
int A,B,C;
int H,M;
cin>>A>>B>>C;
if(B+C<60){
cout<<A<<" "<<B+C;
}else if(B+C>=60){
H = A+((B+C)/60);
M = (B+C)%60;
if(H>=24){
cout<<H-24<<" "<<M;
}else if(H<24){
cout<< H<<" "<<M;
}
}
return 0;
}
#include <iostream>
using namespace std;
int main()
{
int A,B,C;
int H,M;
cin>>A>>B>>C;
H = ((A*60 + B+ C)/60)%24;
M = (A*60+B+C)%60;
cout<<H << " "<<M;
return 0;
}
역시 깔끔한 GPT... 이 방법은 if 문이 필요없더라..
모든 시각을 다 분으로 더해서 분만 더하는 문제로 만들고 새롭게 시간을 정리해주었다.
조건문에서는 어떻게 조건을 정하느냐에 따라 코드의 복잡도가 완전 달라짐 기억하기, 빼먹는 경우 없도록 꼼꼼하게 생각하기