celina의 이것저것
[C++] 백준 2530번 - 인공지능 시계 본문
반응형
문제
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초가 된다.)
접근
나누기를 해서 몫과 나머지를 사용해서 풀어야겠다고 생각했다
코드
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
using namespace std;
int main() {
int a, b, c, d, h, m, s;
scanf("%d %d %d %d", &a, &b, &c, &d);
c += d;
if (c >= 60) {
b += (c / 60);
c %=60;
if (b >= 60) {
a += (b / 60);
b %= 60;
if (a >= 24) {
a = a % 24;
}
}
}
printf("%d %d %d", a, b, c);
return 0;
}
리뷰
처음에는 되게 복잡할 것같았는데 막상 푸니까 생각보다 간단하게 풀렸다.
초가 60이 넘을때, 분이 60이 넘을때, 시가 23을초과할때의 경우를 생각해서 풀었다.
이 경우가 아니면 그냥 더해주기만하면 되기 때문이다
우선 초가 60이 넘으면 초를 60으로 나눠서 몫과 나머지를 구한다.
나머지가 초가 될것이고 몫만큼을 기존 분에 더해서 최종분?을 구한다
이제 두번째로 분이 60이 넘을 경우를 똑같이 반복하면 된다
손코딩을 하고 풀었을 때는 분명히 정답인데 프로그램을 돌려보니까 이상한 답이 나왔다.
그 이유는 내가 순서를 바꿨음!!
//원래 순서는
b += (c / 60);
c %=60;
//처음엔 이렇게 적음
c %=60;
b += (c / 60);
이렇게 순서가 바껴버리니까 기존에 C+D=C 여기 C를 이용해서 나누기를 해야하는데 C%=60이걸 먼저 시행하니까 C+D=C 여기 C가 아닌 여기 C에서 60을나눈 나머지가 C가 되버린 것이다. 그래서 답이 이상했떤것..
다행히 금방 오류를 찾아서 해결했다 첨엔 어려울것같았는데 생각보다 간단하게 풀어서 뿌듯하다 ㅎ
출처
2530번: 인공지능 시계
첫째 줄에 종료되는 시각의 시, 분, 초을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수이며, 분, 초는 0부터 59까지의 정수이다. 디지털 시계는 23시 59분 59초에서 1초가 지나면 0시 0
www.acmicpc.net
'자료구조&알고리즘 > 백준' 카테고리의 다른 글
[C++] 백준 10707번 - 수도요금 (2) | 2023.01.05 |
---|---|
[C++] 백준 5596번 - 시험 점수 (1) | 2023.01.05 |
[C++] 백준 10156번 - 과자 (1) | 2022.12.30 |
[C++] 백준 2480번 - 주사위 세개 (1) | 2022.12.30 |
[C++] 백준 10162번 - 전자레인지 (1) | 2022.12.29 |
Comments