본문 바로가기

BOJ/Node.js

[BOJ / Node.js] 5635. 생일

728x90
 

5635번: 생일

어떤 반에 있는 학생들의 생일이 주어졌을 때, 가장 나이가 적은 사람과 가장 많은 사람을 구하는 프로그램을 작성하시오.

www.acmicpc.net

문제

어떤 반에 있는 학생들의 생일이 주어졌을 때, 가장 나이가 적은 사람과 가장 많은 사람을 구하는 프로그램을 작성하시오.

입력

첫째 줄에 반에 있는 학생의 수 n이 주어진다. (1 ≤ n ≤ 100)

다음 n개 줄에는 각 학생의 이름과 생일이 "이름 dd mm yyyy"와 같은 형식으로 주어진다. 이름은 그 학생의 이름이며, 최대 15글자로 이루어져 있다. dd mm yyyy는 생일 일, 월, 연도이다. (1990 ≤ yyyy ≤ 2010, 1 ≤ mm ≤ 12, 1 ≤ dd ≤ 31) 주어지는 생일은 올바른 날짜이며, 연, 월 일은 0으로 시작하지 않는다.

이름이 같거나, 생일이 같은 사람은 없다.

출력

첫째 줄에 가장 나이가 적은 사람의 이름, 둘째 줄에 가장 나이가 많은 사람 이름을 출력한다.

예제 입력 1 복사

5
Mickey 1 10 1991
Alice 30 12 1990
Tom 15 8 1993
Jerry 18 9 1990
Garfield 20 9 1990

예제 출력 1 복사

Tom
Jerry

 

Solve

  • 주어진 String 데이터를 객체 형식으로 변환하여 각각 프로퍼티를 기준으로 정렬하여 맨 앞값과 맨 뒤값의 이름을 출력해주었습니다.

Code

const input = require("fs").readFileSync("/dev/stdin").toString().trim().split("\n");


const n = +input.shift();
const arr = input.map(el=> {
    const [name, day, mon, year] = el.split(' ');
    return {name, day:+day, mon:+mon, year:+year}
});

arr.sort((a,b)=>{
    if(a.year > b.year) return 1;
    if(a.year < b.year) return -1;
    if(a.mon > b.mon) return 1;
    if(a.mon < b.mon) return -1;
    if(a.day > b.day) return 1;
    if(a.day < b.day) return -1;
})

console.log(arr[n-1].name)
console.log(arr[0].name);

 

'BOJ > Node.js' 카테고리의 다른 글

[BOJ / Node.js] 2529. 부등호  (0) 2023.03.23
[BOJ / Node.js] 17298. 오큰수  (0) 2023.03.22
[BOJ / Node.js] 1120. 문자열  (0) 2023.03.20
[BOJ / Node.js] 1918. 후위 표기식  (0) 2023.03.19
[BOJ / Node.js] 2638. 치즈  (0) 2023.03.18