[BOJ] #3029 - 경고

👻 경고

👉🏻 문제 보러가기 👈🏻


🌱 문제

창영마을에서 정인이의 반란은 실패로 끝났다. (3028번)

테러리스트로 변신한 정인이는 창영마을에 경고를 하려고 한다.

사실 정인이는 창영마을에서 제일 착한사람이다. 따라서, 사람들을 다치지 않게 하려고 한다.

유튜브에서 폭발에 대한 동영상을 찾아보다가, 그는 나트륨을 물에 던지면 폭발한다는 사실을 알게 되었다.

정인이는 창영마을의 중심을 지나는 “강산강” 근처에 숨어있다가, 나트륨을 위의 동영상처럼 물에 던질 것이다.

현재 시간과 정인이가 나트륨을 던질 시간이 주어졌을 때, 정인이가 얼마나 숨어있어야 하는지 구하는 프로그램을 작성하시오. (정인이는 적어도 1초를 기다리며, 많아야 24시간을 기다린다.)

  • 시간 제한 : 1초
  • 메모리 제한 : 128 MB

🌱 입력

첫째 줄에 현재 시간이 hh:mm:ss 형식으로 주어진다.(시, 분, 초) hh는 0보다 크거나 같고, 23보다 작거나 같으며, 분과 초는 0보다 크거나 같고, 59보다 작거나 같다.
둘째 줄에는 나트륨을 던질 시간이 위와 같은 형식으로 주어진다.


🌱 출력

첫째 줄에 정인이가 기다려야 하는 시간을 입력과 같은 형식으로 출력한다.


🌱 예제


🪐 입출력 1

  • 입력
    20:00:00
    04:00:00
    
  • 출력
    08:00:00
    

🪐 입출력 2

  • 입력
    12:34:56
    14:36:22
    
  • 출력
    02:01:26
    

👻 풀이

#include <iostream>
#include <sstream>
#include <string>
#include <vector>
#include <iomanip>
using namespace std;
vector<int> split(string str, char deli)
{
    vector<int> ret;
    stringstream ss(str);
    string temp;
    while (getline(ss, temp, deli))
        ret.push_back(stoi(temp));
    return ret;
}
string a, b;
int ret[3];
int main()
{
    // 경고
    cin >> a >> b;
    if (a == b) 
    {
        cout << "24:00:00";
        return 0;
    }

    vector<int> v1 = split(a, ':');
    vector<int> v2 = split(b, ':');
    ret[2] = v2[2] - v1[2];
    if (ret[2] < 0) 
    {
        ret[2] += 60;
        v2[1]--;
    }
    ret[1] = v2[1] - v1[1];
    if (ret[1] < 0) 
    {
        ret[1] += 60; 
        v2[0]--;
    }
    ret[0] = v2[0] - v1[0];
    if (ret[0] < 0) 
        ret[0] = 24 - v1[0] + v2[0];

    cout << setfill('0') << setw(2) << ret[0] << ":";
    cout << setfill('0') << setw(2) << ret[1] << ":";
    cout << setfill('0') << setw(2) << ret[2];
    return 0;
}
  • 시간 : 0 ms
  • 메모리 : 2080 KB

👻 글을 마치며

잘 푼 것 같은데 틀려서 멘붕이 왔었다. 백준은 틀린 이유를 정확히 알려주지 않아 더 어려운 것 같다. 🥲 찾아보니 결국 같은 시간을 입력했을 때 처리를 해주지 않아 발생했던 것이다. 덕분에 2시간 정도 잡고 있었는데, 시간을 더 줄이려 노력해야겠다.


소스코드 보러가기

Categories:

Updated:

Leave a comment