Studying/Algorithms

[알고리즘 떠먹여 주는 남자] 백준 2884 - 알람 시계 for Node.js

국장 지킴이 앨런 2022. 4. 2. 15:16
반응형

https://acmicpc.net/problem/2884 

 

2884번: 알람 시계

상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다. 상근이는 모든 방법을 동원해보았지만,

www.acmicpc.net

문제

상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다.

상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다.

이런 상근이를 불쌍하게 보던, 창영이는 자신이 사용하는 방법을 추천해 주었다.

바로 "45분 일찍 알람 설정하기" 이다.

이 방법은 단순하다. 원래 설정되어 있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘 것이기 때문이다. 이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다.

현재 상근이가 설정한 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 두 정수 H와 M이 주어진다. (0 ≤ H ≤ 23, 0 ≤ M ≤ 59) 그리고 이것은 현재 상근이가 설정한 놓은 알람 시간 H시 M분을 의미한다.

입력 시간은 24시간 표현을 사용한다. 24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다. 시간을 나타낼 때, 불필요한 0은 사용하지 않는다.

출력

첫째 줄에 상근이가 창영이의 방법을 사용할 때, 설정해야 하는 알람 시간을 출력한다. (입력과 같은 형태로 출력하면 된다.)

예제 입력 1 복사

10 10

예제 출력 1 복사

9 25

예제 입력 2 복사

0 30

예제 출력 2 복사

23 45

예제 입력 3 복사

23 40

예제 출력 3 복사

22 55

풀이

이번 문제도 꽤나 간단합니다. 문제를 잘 읽어 보시고 상황에 맞는 시간과 분 값을 계산해서 출력 해 주면 되는 문제입니다. 코드를 보기에 앞서 제가 생각한 조건들이 어떤 것들이 있는지 나열해 보겠습니다.

  • 만약 주어진 분 값이 45보다 작을 경우
    • 분: (주어진 분 값 - 45) + 60
    • 시간: 만약 주어진 시간 값이 0일 경우 23, 그 외에 시간 - 1
  • 주어진 분 값이 45보다 크거나 같을 경우, 분 - 45. 이 경우에 시간은 바뀌지 않음.

위의 경우를 고려해 준다면 어렵지 않게 문제를 풀 수 있습니다. 제가 작성한 코드는 이렇습니다.

const fs = require('fs');
let input = fs.readFileSync(`/dev/stdin`).toString();

input = input.split(' ').map(input => Number(input));
const hour = input[0],
      minute = input[1];

let targetHour = 0,
    targetMinute = 0;

if (minute >= 45) {
  targetMinute = minute - 45;
  targetHour = hour;
} else {
  targetMinute = (minute - 45) + 60;
  targetHour = hour === 0 ? 23 : (hour - 1);
}

console.log(`${targetHour} ${targetMinute}`);

이렇게 오랜만에 알고리즘 문제를 풀어 보았는데요. 요즘 이직 준비 때문에 자바스크립트 기초에 중점을 두고 공부하다 보니 알고리즘을 풀지 않은 지 꽤 되었습니다. 앞으로는 시간 좀 더 할애해서 알고리즘도 조금씩 더 풀어야 할 것 같습니다만 어려운 문제는 몇시간씩도 잡아먹고 하니 참 쉽지가 않네요.. 알고리즘 넘나 어려운거 ㅠ

 

그럼 다음 알고리즘으로 또 찾아 뵙겠습니다 모두 열공하세요!

반응형