[백준] 2480. 주사위 세개(feat. Javascript / node.js) 알고리즘

준리·2022년 5월 2일
0

자료구조알고리즘

목록 보기
18/38
post-thumbnail

조건문 단계

: 주사위 세개[2480]

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.

같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.
예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3×100으로 계산되어 1,300원을 받게 된다. 또 3개의 눈이 2, 2, 2로 주어지면 10,000+2×1,000 으로 계산되어 12,000원을 받게 된다. 3개의 눈이 6, 2, 5로 주어지면 그중 가장 큰 값이 6이므로 6×100으로 계산되어 600원을 상금으로 받게 된다.

3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

예제 입력

첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다. 

3 3 6

2 2 2

6 2 5

예제 출력

첫째 줄에 게임의 상금을 출력 한다.

1300

12000

600

제출

const input = require("fs")
    .readFileSync("/dev/stdin")
    .toString()
    .split(" ")
    .map((value) => +value);

input.sort(function (a, b) {
    return b - a;
});

const [A, B, C] = input;

if (A !== B && A !== C && B !== C) {
    console.log(A * 100);
} else if (A === B && B !== C) {
    console.log(1000 + A * 100);
} else if (B === C && C !== A) {
    console.log(1000 + C * 100);
} else if (C === A && A !== B) {
    console.log(1000 + C * 100);
} else {
    console.log(10000 + A * 1000);
}




무엇을 해결해야 하는가?

빈틈을 주면 안된다. 예외를 만들면 안된다는 말이다.
조건문을 하나씩 작성하면서 하나씩 조건을 추가해갔다.

제일 첫 줄 모두가 같지 않을 때를 추가하면서 생긴 문제는 주사위 중 가장 큰 수를 찾아 내는 것이었다. input에 담긴 3개의 주사위를 sort()로 내림차순 정렬을 먼저 하고 비구조할당을 진행하였다.

그렇게 되면 문제에서 말한 그 중 가장 큰 눈(A)를 찾아 낼 수 있게 된다.

모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.

그후론 2번 조건 같은 눈이 2개만 나오는 경우를 노가다 식으로 풀어 낸 뒤

같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.

최종 조건은 else로 담아서 출력해서 정답이 되었다.

일단 풀었다는 것에 대해 기분이 좋았다.

숏코딩

let [a,b,c] = require("fs").readFileSync("/dev/stdin").toString().trim().split(" ").map(Number).sort((x,y)=> x-y);

if(a==b && b==c){
  console.log(10000 + a*1000)
} else if(a==b || b==c){
  console.log(1000 + b*100)
} else {
  console.log(c*100)
}

else if(a==b || b==c) 이렇게하면 2번째 조건이 쉽게 풀린다니 수학적 머리가 아직 한참 없다는 것을 깨달으며 배워간다.

profile
트렌디 풀스택 개발자

0개의 댓글