블로그를 이전하였습니다. 2023년 11월부터 https://bluemiv.github.io/에서 블로그를 운영하려고 합니다. 앞으로 해당 블로그의 댓글은 읽지 못할 수 도 있으니 양해바랍니다.
반응형
문제
문제 풀이
input 값들을 map 자료구조에 담아서, 동일한 주사위 눈의 개수가 몇개인지 파악하도록 했다.
- 만약 map의 key 값이 1개인 경우, 주사위 3개의 눈이 모두 동일한 경우 (e.g. 6, 6, 6)
- 2개인 경우, 주사위 눈 중 2개가 동일하고 1개가 다른 경우 (e.g. 2, 2, 5)
- 그 외에는 주사위 3개가 모두 눈이 다른 경우 (e.g. 2, 3, 6)
const solution = (input) => {
const ns = input.split(' ').map((s) => +s);
const nm = ns.reduce((acc, n) => {
if (acc[n]) {
return { ...acc, [n]: acc[n] + 1 };
} else {
return { ...acc, [n]: 1 };
}
}, {});
switch (Object.keys(nm).length) {
case 1:
return ns[0] * 1000 + 10000;
case 2:
return +Object.entries(nm).find((_n) => _n[1] === 2)[0] * 100 + 1000;
default:
return Math.max(...ns) * 100;
}
};
const print = (input) => console.log(solution(input + ''));
process.stdin.on('data', print);
전체 코드
https://github.com/bluemiv/Algorithm/blob/master/baekjoon/nodejs/src/ex02/ex2480.js
풀이 결과
관련 글
2022.07.21 - [Algorithm/Beakjoon] - jest 단위테스트를 이용하여 백준 알고리즘 문제 편하게 풀기
반응형
'Algorithm > Beakjoon' 카테고리의 다른 글
백준 10950번 / A+B - 3 (nodejs 알고리즘 풀이) (0) | 2022.07.26 |
---|---|
백준 2739번 / 구구단 (nodejs 알고리즘 풀이) (0) | 2022.07.25 |
백준 2525번 / 오븐 시계 (nodejs 알고리즘 풀이) (0) | 2022.07.23 |
백준 2884번 / 알람 시계 (nodejs 알고리즘 풀이) (0) | 2022.07.22 |
jest 단위테스트를 이용하여 백준 알고리즘 문제 편하게 풀기 (1) | 2022.07.21 |