백준(python) 2530번 인공지능 시계 풀이

zhixian_dev.log·2022년 9월 26일
0

백준

목록 보기
8/12

👁‍🗨백준 2530번 인공지능 시계

⭕백준 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초가 된다.)

예제입력1

14 30 0
200

예제출력1

14 33 20

예제입력2

17 40 45
6015

예제출력2

19 21 0

예제입력3

23 48 59
2515

예제출력4

0 30 54

❓풀이 방법❓

🤷‍♀️내가 푼 방법은 백준에서 오답처리되는 풀이지만...!!!

H,M,S,timer를 입력받은 후, s와 timer를 합친 후 시작했다!
그 후 if문을 사용하여 S,M,H 값별로 S>=60, M>=60, H>=24일 경우 값을 올려주고 빼주는... 프로세스로 진행해주었고 구글 코랩에서 문제의 입출력 예제를 입력해보았을 때 예제와 동일한 출력이 나왔으나
백준 제출에서는 틀렸다고나왔다🤦‍♀️🤦‍♀️😥😥

백준 2530번 풀이

H, M, S = map(int,input().split())
timer = int(input())
S += timer
if S >= 60:
  T1 = S // 60
  M += T1
  S -= (T1 * 60)
if M >= 60:
  T2 = M // 60
  M -= (T2 * 60)
  H += T2
if H >= 24:
  H -= 24
print(H, M, S)
  • 여기서 또 내가 주의해야할 부분은!!

    🔴계속해서 s가 59 초과, m이 59 초과, h가 24초과를 if/elif문으로 감싸버려서 h,m값이 제대로 출력이 안되는 현상을 겪었다.
    당연히,,, 틀린거지만 이걸 계속 생각을 못하고 elif문 안에 감싸서 풀고있었다는,,,,
    이부분은 이제 알았으니 잘 주의해주자❗❗

이제 내 풀이를 보았으니 다른 분들의 풀이를 한번 가져와보았다...

1) 풀이1
이 풀이가 2번 풀이보다 내 기준(?) 더 간단해보인다...!
아직까진 어떤게 더 좋은코드... 이런건 보이지않는 수준이라...ㅎㅎ
H,M,S 값을 input 받고 S값에 바로 타이머값을 더해주었다.
더해준 후 S/60한 값을 M에 추가, M/60한 값을 H에 추가하는 식으로 코드를 짜고, 각각 24, 60, 60으로 % 연산자를 사용하여 24, 60, 60일 경우 0으로 만들어주게끔 진행되었다!

풀이1

H, M, S = map(int, input().split())
S = S + int(input()) 
M = M + int(S/60)
H = H + int(M/60)
H = H % 24
M = M % 60
S = S % 60
print("%s %s %s" %(H, M, S))

2) 풀이2
이건 뭔가 나의 풀이와 비슷~ 해보이지만 나와 딱 다른 포인트가 있다.
T = T // 60 이부분인데, 이걸 왜 하나,,, 하면서 print를 찍어보았는데 그제서야 왜 저런식으로 풀이를 했는지 알게되었다.
만약에 T 값이 200이 들어갈 경우, 첫번째 T // 60 에서는 3, 두번째에서는 0, 세번째에서도 0이 나오게되어 각 S, M, H 값에 더해지게 되는 코드이다.

풀이2

H, M, S = map(int, input().split())
T = int(input()) 
S += T % 60
T = T // 60
if S >= 60:
    S -= 60
    M += 1
M += T % 60
T = T // 60
if M >= 60:
    M -= 60
    H += 1
H += T % 24
if H >= 24:
    H -= 24
print(H,M,S)

뭔가 많이 막히고 틀렸던 문제지만 다른사람의 시선에서는 이런식으로도 풀리는구나... 싶었던 문제였던것같다.
(모든 문제가 다 그렇겠지만😎)

💬혹시나 저의 풀이가 왜 백준에서 틀린지 아시는분은 댓글 남겨주시면 감사하겠습니다!

profile
💻 화나면 물어요

1개의 댓글

comment-user-thumbnail
2022년 12월 6일

0시 0분 0초에서 50만 초 더해보세요. 반례 있음.

답글 달기