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번째 조건이 쉽게 풀린다니 수학적 머리가 아직 한참 없다는 것을 깨달으며 배워간다.