[★2][백준2525번]오븐 시계 (JAVA)

Date:     Updated:

카테고리:

태그:

[★2][백준2525번]오븐 시계 (JAVA)

2525번 문제 ☞ https://www.acmicpc.net/problem/2525

난이도 ☞ [★2]

오븐 시계

  • 문제
    • 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

내가 푼 풀이

이번 문제는 입력 받은 시와 분을 분으로 환산한 뒤에 걸리는 시간(분)을 더하여, 다시 시와 분으로 나눌 것인지 아니면 입력 받은 걸리는 시간(분)을 시와 분으로 나누어 각각 더해줄 것인지를 먼저 생각을 해보고 문제 풀이에 임하면 조금 더 수월히 진행 할 수 있다. 개인적으로 더 쉬워보이는 방법인 입력 받은 시와 분을 분으로 환산을 하는 법으로 구현하도록 하겠습니다. 환산하는 방법은 아래와 같습니다.

	int min = 60 * a + b;

분으로 환산한 뒤에 걸리는 시간(c)을 더해줘야합니다.

	int min = 60 * a + b;
	min = min + c;

더해 준 값을 시와 분으로 다시 나누어야합니다.

	int min = 60 * a + b;
	min = min + c;
	
	int h = (min/60) % 24;
	int m = min % 60;

이번 문제는 시간을 시, 분으로 나누고 분으로 바꾸고 하는 방법을 안다면 수월한 문제가 될 것이라고 보여집니다.
위의 코드를 활용하여 각각 ScannerBufferedReader로 풀이하여 작성을 해보았습니다. 먼저 Scanner입니다.

[ 풀이 1 ]

메모리 : 18424KB
시간 : 236ms

Scanner

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner s = new Scanner(System.in);
		
		int a = s.nextInt();		// 시(1)
		int b = s.nextInt();		// 분(2)
		
		int c = s.nextInt();		// 걸리는 시간(3)
		
		s.close();
		
		int min = 60 * a + b; 		// (1)+(2)를 분으로 변환(4)
		min = min + c;			    // (4)+(3)을 더해줌(5)
		
		// (5)를 시 분으로 나눔
		int h = (min/60) % 24;
		int m = min % 60;
		
		System.out.println(h + " " + m);
		
	}
}

다음은 BufferedReader입니다.

[ 풀이 2 ]

메모리 : 16036KB
시간 : 152ms

BufferedReader, StringTokenizer

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));
		StringTokenizer st = new StringTokenizer(br.readLine(), " ");
		
		int a = Integer.parseInt(st.nextToken());		// 시(1)
		int b = Integer.parseInt(st.nextToken());		// 분(2)
		
		int c = Integer.parseInt(br.readLine());		// 걸리는 시간(3)
		
		int min = 60 * a + b; 		// (1)+(2)를 분으로 변환(4)
		min = min + c;				// (4)+(3)을 더해줌(5)
		
		// (5)를 시 분으로 나눔
		int h = (min/60) % 24;
		int m = min % 60;
		
		System.out.println(h + " " + m);
		
	}
}

Scanner보다는 BufferedReader가 성능이 우수한 걸 알 수 있습니다.

BKJN 카테고리 내 다른 글 보러가기

댓글 남기기