Algorithm/Baekjoon(Java)

[백준/JAVA] 2525 : 오븐 시계

비망노트 2022. 7. 4. 21:47
문제

KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다.

인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다.

그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.

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

훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때,

오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.

 

입력

첫째 줄에는 현재 시각이 나온다.

현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다.

두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다. 

 

출력

첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다.

(단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)

 

예제 입력 예제 출력
14 30
20
14 50
17 40
80
19 0
23 48
25
0 13

 

⭕ 풀이

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main{
    public static void main(String[] args)throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String nowTime = br.readLine();
        StringTokenizer st = new StringTokenizer(nowTime);
        
        int hour = Integer.parseInt(st.nextToken());
        int minute = Integer.parseInt(st.nextToken());
        int time = Integer.parseInt(br.readLine());
        
        int endH = hour;
        int endM = 0;
        
        if(minute+time>=60){
            int plusH = (minute+time) / 60;
            endM = (minute+time) % 60;
            
            if(hour+plusH>23){
                endH = (hour+plusH) % 24;
            }else{
                endH += plusH;                
            }
        }else{
            endM = minute+time;
        }
        System.out.printf("%d %d",endH,endM);
    }
}

✅ 우선 현재시간의 분과, 필요조리시간을 기준으로 값이 변할 수 있으니 첫if문을 60이상일경우로 조건을 주었다.

또한 이전문제처럼 변동 시간이 45분이어서 시간을 1올릴지 1내릴지가아니고

이번문제는 변동시간이 0분에서 1000분까지이므로 플러스되는 시간을 60으로 나누어 구해주었다.

끝나는 분은 60으로 나눈 나머지를 기준으로했으며 24시부터는 0시라고 표현되므로 조건을 추가해주었다.

 

+)  nowTime으로 readLine을 받지말고

StringTokenizer st = new StringTokenizer(br.readLine()); 이렇게 처음부터 받으면 코드를 더 줄일 수 있었다

 

 

✅ 다른분의 풀이

import java.io.*;
import java.util.*;

public class Main {
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine());
		int h = Integer.parseInt(st.nextToken());
		int m = Integer.parseInt(st.nextToken());
		int t = Integer.parseInt(br.readLine());
		int t_h = t/60;
		int t_m = t%60;
		
		h += t_h;
		m += t_m;
		h += m/60;
		h %= 24;
		m %= 60;
		
		System.out.println(h + " " + m);
	}
}

요리에 걸리는 시간을 처음부터 60으로 나눈값과 60으로 나눈 나머지값을 선언하고

시와 분에 더한뒤  m(분)을 60으로 나눈 즉 추가될 시간을 h(시)에 더하고

h(시)는 24시가 아닐경우 애초에 %24해도 그값이기 때문에..

마지막으로 m에도 60으로나눈 나머지값..

if문을 안쓰고도 이렇게 표현할 수 있구나 ,,

알고리즘은 볼수록 신기한 풀이가 많다

 

 

 

-출처

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

'Algorithm > Baekjoon(Java)' 카테고리의 다른 글

[백준/JAVA] 2739 : 구구단  (0) 2022.07.06
[백준/JAVA] 2480 : 주사위 세개  (0) 2022.07.05
[백준/JAVA] 2884 : 알람 시계  (0) 2022.07.03
[백준/JAVA] 14681 : 사분면 고르기  (0) 2022.07.03
[백준/JAVA] 2753 : 윤년  (0) 2022.07.03