프라이D
프라이Develog(❁´◡`❁)
프라이D
전체 방문자
오늘
어제
  • ALL (378)
    • TDD, Cleancode with JavaScr.. (5)
    • 프로젝트 (32)
      • work (3)
      • 직접 만드는 기술 블로그 (2)
      • 데일리 옥션 (19)
      • 모락모락 (8)
    • Computer Science (1)
    • Algorithm & 자료구조 (94)
      • 알고리즘 w.JavaScript (53)
      • 자료구조 (5)
      • (인프런) 자바스크립트 알고리즘 문제풀이 (34)
    • JavaScript (45)
      • JavaScript (41)
      • 모던 자바스크립트 Deep Dive (4)
    • WEB (13)
    • 회고 (12)
    • TIL (109)
    • WIL (7)
    • Stacks (20)
      • React.js (6)
      • Next.js (1)
      • Redux (3)
      • Node.js (2)
      • GIT (2)
      • SAP (1)
    • 15일 메이킹 프로젝트 (15)
    • 이전 기록 (14)
    • ETC. (5)
    • ---------------2021 (6)
      • 내일배움단-웹개발 5주 (2)
      • 정보처리기사 (4)

블로그 메뉴

  • 홈
  • 태그
  • 미디어로그
  • 위치로그
  • 방명록

공지사항

인기 글

태그

  • 내일배움단
  • JavaScript
  • 모던자바스크립트딥다이브
  • 자바스크립트알고리즘
  • 알고리즘
  • 2023 인프콘 후기
  • MySQL
  • 스파르타코딩클럽
  • 자바스크립트비트마스크
  • 비트마스크
  • 내일배움카드
  • nomadcoder
  • 코딩프로젝트
  • nomadcoders
  • 코드스테이츠
  • vanilaJS
  • 자바스크립트
  • 투포인터알고리즘
  • 국비지원
  • Til

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
프라이D

프라이Develog(❁´◡`❁)

Algorithm & 자료구조/알고리즘 w.JavaScript

[알고리즘] 백준 2525번: 오븐 시계 W_node.js

2022. 4. 24. 23:49

문제

 

2525번: 오븐 시계

첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)

www.acmicpc.net

KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.

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

훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.

풀이1

// 백준 제출용
const readFileSyncAddress = '/dev/stdin'; 

const fs = require('fs');
let [time, C] = fs.readFileSync(readFileSyncAddress).toString().trim().split(/\n/g);

let [H, M] = time.split(/\s/g).map(v => +v);
C = Number(C);

if (C > 60) {
    M += C % 60;
    H += Math.floor(C / 60);
} else if (C < 60) {
    M += C;
} else if ( C === 60) {
    M = 0;
    H++;
}

if (M >= 60) {
    M = M % 60;
    H += Math.floor(M / 60);
    if(Math.floor(M / 60) === 0) H++;
} 

if (H > 24) {
    H = H % 24;
} else if (H === 24) H = 0;

//제출
console.log(`${H} ${M}`);

풀이2

// 백준 제출용
const readFileSyncAddress = '/dev/stdin'; 

const fs = require('fs');
let [time, C] = fs.readFileSync(readFileSyncAddress).toString().trim().split(/\n/g);

let [H, M] = time.split(/\s/g).map(v => +v);
C = Number(C);

const currT = (H * 60) + M;
const completionT = currT + C;

H = parseInt(completionT / 60);
M = completionT % 60;

if(H > 23) H = H % 24;

//제출
console.log(`${H} ${M}`);
  • 전체 시간을 분단위로 바꿔 계산한 뒤, 결과값을 다시 시, 분으로 변환하는 풀이법이 있어 다시 풀어봤다. 시간 관련 문제는 특정 단위로 변환하여 접근하는 것이 더 편한 것 같다.
저작자표시 (새창열림)

'Algorithm & 자료구조 > 알고리즘 w.JavaScript' 카테고리의 다른 글

[알고리즘] 백준 10950번: A+B - 3 W_node.js  (0) 2022.04.25
[알고리즘] 백준 2480번: 주사위 세개 W_node.js  (0) 2022.04.25
[알고리즘] 백준 2884번: 알람 시계 W_node.js  (2) 2022.04.21
[알고리즘] 백준 11723번: 집합 (비트마스크) W_node.js  (0) 2022.03.22
[알고리즘] 비트마스크 Bit Mask  (0) 2022.03.20
    'Algorithm & 자료구조/알고리즘 w.JavaScript' 카테고리의 다른 글
    • [알고리즘] 백준 10950번: A+B - 3 W_node.js
    • [알고리즘] 백준 2480번: 주사위 세개 W_node.js
    • [알고리즘] 백준 2884번: 알람 시계 W_node.js
    • [알고리즘] 백준 11723번: 집합 (비트마스크) W_node.js
    프라이D
    프라이D
    틀린내용 정정 및 개선사항은 언제든지 댓글 달아주세요 :D

    티스토리툴바