[백준 | Javascript] 2480

박기영·2022년 5월 16일
0

백준

목록 보기
20/127

조건문 7단계
2480번. 주사위 세개

문제

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

  1. 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다.
  2. 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다.
  3. 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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개의 눈이 빈칸을 사이에 두고 각각 주어진다.

출력

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

예제 입출력

예제 입력 1

3 3 6

예제 출력 1

1300

예제 입력 2

2 2 2

예제 출력 2

12000

예제 입력 3

6 2 5

예제 출력 3

600

solution

const fs = require('fs');

const numbers = fs.readFileSync('/dev/stdin').toString().split(' ').map(Number);

const a = numbers[0];
const b = numbers[1];
const c = numbers[2];

let money = 0;
let maxNum = 0;

if(a === b && a === c){
  	money = 10000 + a*1000;
} else if(a === b || a === c || b === c){
	if(a === b || a === c){
      money = 1000 + a*100;
    } else{
    	money = 1000 + b*100;
    }
} else{
  	maxNum = Math.max(...numbers);
 	money = maxNum*100;
}

console.log(money);

해설

중복되는 숫자를 찾는 방법을 어떻게 하느냐에 따라 문제 난이도가 급격하게 달라진다. 특정 숫자를 기준으로 잡는 것이 가장 쉬운 방법인 것 같다.
a,b,c라는 세 숫자가 있을 때 a라는 숫자를 기준으로 찾는다면 ab, ac, bc만 비교하면 문제 조건 1,2,3번을 모두 대조해볼 수 있다.
1. 모든 숫자가 같으려면 ab, ac가 각각 같음을 만족하면 된다.
2. 두 숫자가 같으려면 ab, ac, bc 중 하나라도 만족하면 된다.
세 경우의 수 중 어떤 것이 참이 되었는지 모르므로 내부에 한번 더 조건문을 달아서 숫자를 선택하게 만든다.
3. 모든 숫자가 다르려면 1,2번을 제외한 모든 경우의 수이다. Math.max()를 사용해서 배열 원소 중 가장 큰 숫자를 선택했다. 배열을 입력해줄 때 spread 연산자(...)를 꼭 사용해야한다는 것을 잊지말자!

profile
나를 믿는 사람들을, 실망시키지 않도록

0개의 댓글