백준 문제 풀이

05. 백준 2480 JavaScript 주사위 세개 (풀이 설명)

프론트개미 2022. 3. 31. 20:48

문제

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

 

문제 풀이

먼저 각가 주사위의 숫자를 알 수 있게 3개의 주사위를 변수로 지정해준다.

const fs = require('fs');
const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt';
let input = fs.readFileSync(filePath).toString().split(' ');

let d1 = parseInt(input[0]);
let d2 = parseInt(input[1]);
let d3 = parseInt(input[2]);

 

 

첫 번째 if문에는 모든 주사위가 같은 숫자가 나왔을 경우를 === 와 &&(and)를 사용하여 작성한다.

const fs = require('fs');
const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt';
let input = fs.readFileSync(filePath).toString().split(' ');

let d1 = parseInt(input[0]);
let d2 = parseInt(input[1]);
let d3 = parseInt(input[2]);

if(d1 === d2 && d2 === d3){

    console.log(10000+d1*1000);

}

 

 

두 번째 경우는 else if를 사용하여 작성하는데, 3개의 주사위중 2개가 동일한 숫자가 나왔을 경우에 작동이 되어야 하기 때문에 2개의 주사위가 같을 경우의 수를 모두 작성해주었다. 

그리고 같은 주사위의 번호를 액수에 곱해주기 위해 식을 2개로 분리해서 어떤 주사위든 같은 숫자가 2개 나왔을 때 주사위 번호를 액수에 곱할 수 있게 작성했다.

const fs = require('fs');
const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt';
let input = fs.readFileSync(filePath).toString().split(' ');

let d1 = parseInt(input[0]);
let d2 = parseInt(input[1]);
let d3 = parseInt(input[2]);

if(d1 === d2 && d2 === d3){

    console.log(10000+d1*1000);

}else if(d1 === d2 || d1 === d3){

    console.log(1000+d1*100);

}else if(d2 === d3){

    console.log(1000+d2*100);

}

 

 

세 번째로 모든 주사위가 다른 숫자가 나왔을 때 조건식은 !== (불일치 연산자)를 사용하여 작성한다.

그리고 가장 큰 숫자에 액수를 곱해줘야 하기 때문에 Math.max( );를 사용하여 d1, d2, d3 중 가장 큰 숫자를 불러와 계산을 해줬다.

const fs = require('fs');
const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt';
let input = fs.readFileSync(filePath).toString().split(' ');

let d1 = parseInt(input[0]);
let d2 = parseInt(input[1]);
let d3 = parseInt(input[2]);

if(d1 === d2 && d2 === d3){

    console.log(10000+d1*1000);

}else if(d1 === d2 || d1 === d3){

    console.log(1000+d1*100);

}else if(d2 === d3){

    console.log(1000+d2*100);

}else if(d1 !== d2 && d1 !== d3 && d2 !== d3){

    console.log(Math.max(d1,d2,d3)*100);

};

*Math.max( );는 ( )안에서 가장 값이 큰 요소를 불러올 수 있는 코드이다.