728x90

문제

KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다. 

또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다. 

훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.

 

입력

첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다. 

 

출력

첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)

 

예제 입력 1 

14 30
20

 

예제 출력 1

14 50

 

예제 입력 2

17 40
80

 

예제 출력 2 

19 0

 

예제 입력 3 

23 48
25

 

예제 출력 3

0 13

 

출처

Olympiad > 한국정보올림피아드 > 한국정보올림피아드시․도지역본선 > 지역본선 2012 > 초등부 1번

  • 문제의 오타를 찾은 사람: alkyne
  • 데이터를 추가한 사람: ckd1675

 

알고리즘 분류

  • 수학
  • 사칙연산

 

문제 출처

https://www.acmicpc.net/problem/2525

 

2525번: 오븐 시계

첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)

www.acmicpc.net

 


 

문제 해결 방법

  • 먼저 입력 받은 시간의 값(hour)과 분의 값(minute)을 으로 단위를 통일한 후, 입력 받은 분의 값(time)을 더해준다.
    • minute = (hour * 60) + minute + time
  • 24시간 표현을 사용하므로, 시간의 값은 항상 0 이상 23이하인 수로 출력되어야 한다. 조건문을 이용하여 문제를 해결하기 위해 삼항 연산자(? :)를 사용하여 시간의 값이 24 이상인 경우 % 연산 결과가 시간의 값이 되도록 하였다.
    • hour = (minute / 60) >= 24 ? (minute / 60) % 24 : (minute / 60)
  • 의 값은 항상 0 이상 59이하인 수로 출력되어야 한다.
    • minute = minute % 60
  • 최종적으로 계산된 시간의 값과 분의 값이 출력되도록 하여 문제를 해결하였다.

 

코드

#include <iostream>
using namespace std;

int main() {
    cin.tie(NULL);
    cout.tie(NULL);
    ios_base::sync_with_stdio(false);

    int hour, minute, time;

    cin >> hour >> minute >> time;

    minute = (hour * 60) + minute + time;
    hour = (minute / 60) >= 24 ? (minute / 60) % 24 : (minute / 60);    // or hour = (minute / 60) % 24;
    minute = minute % 60;

    cout << hour << " " << minute << endl;

    return 0;
}

 

채점 결과

 

참고

삼항 연산자(Ternary Operator)

  • if ~ else 문을 대신하여 사용할 수 있는 연산자로 조건 연산자라고도 불린다.
  • 다른 언어에는 존재하지 않는 C 언어와 C++ 만의 독특한 연산자이다.
  • C++ 에서 유일하게 피연산자를 3개나 가지는 조건 연산자이다.
  • 반환값1반환값2자료형(타입)을 맞춰줘야 한다.
조건식 ? 반환값1 : 반환값2    // 조건식이 true일 경우 반환값1을, false일 경우 반환값2를 반환한다.

 

세갈래 연산자(Three-Way Comparison Operator)

  • 우주선 연산자라고도 불린다.
  • C++20 부터 지원되기 시작하였다.
  • 사용하기 위해 <compare> 헤더를 불러와야 한다.
a <=> b
// a < b : -1 출력
// a == b : 0 출력
// a > b : 1 출력

 

728x90

'Problem Solving > BOJ' 카테고리의 다른 글

[BOJ-8393][C++] 합  (0) 2022.07.09
[BOJ-10950][C++] A+B - 3  (0) 2022.07.09
[BOJ-2739][C++] 구구단  (0) 2022.07.09
[BOJ-2480][C++] 주사위 세개  (0) 2022.07.08
[BOJ-2884][C++] 알람 시계  (0) 2022.07.08
[BOJ-14681][C++] 사분면 고르기  (0) 2022.07.08
[BOJ-2753][C++] 윤년  (0) 2022.07.08
[BOJ-9498][C++] 시험 성적  (0) 2022.07.08