► JS Algorithm/Programmers
[Programmers] JavaScript 알고리즘 | Lv.0 주사위 게임 2
다람트리
2024. 1. 15. 20:51
반응형
🔒 문제 설명
1부터 6까지 숫자가 적힌 주사위가 세 개 있습니다. 세 주사위를 굴렸을 때 나온 숫자를 각각 a, b, c라고 했을 때 얻는 점수는 다음과 같습니다.
- 세 숫자가 모두 다르다면 a + b + c 점을 얻습니다.
- 세 숫자 중 어느 두 숫자는 같고 나머지 다른 숫자는 다르다면 (a + b + c) × (a² + b² + c² )점을 얻습니다.
- 세 숫자가 모두 같다면 (a + b + c) × (a² + b² + c² ) × (a³ + b³ + c³ )점을 얻습니다.
세 정수 a, b, c가 매개변수로 주어질 때, 얻는 점수를 return 하는 solution 함수를 작성해 주세요.
🔒 제한사항
- a, b, c는 1이상 6이하의 정수입니다.
🔒 입출력 예
a | b | c | result |
2 | 6 | 1 | 9 |
5 | 3 | 3 | 473 |
4 | 4 | 4 | 110592 |
🔒 입출력 예 설명
입출력 예 #1
- 예제 1번에서 세 주사위 숫자가 모두 다르므로 2 + 6 + 1 = 9점을 얻습니다. 따라서 9를 return 합니다.
입출력 예 #2
- 예제 2번에서 두 주사위 숫자만 같으므로 (5 + 3 + 3) × (5² + 3² + 3² ) = 11 × 43 = 473점을 얻습니다. 따라서 473을 return 합니다.
입출력 예 #3
- 예제 3번에서 세 주사위 숫자가 모두 같으므로 (4 + 4 + 4) × (4² + 4² + 4² ) × (4³ + 4³ + 4³ ) = 12 × 48 × 192 = 110,592점을 얻습니다. 따라서 110592를 return 합니다.
🔐 solution of mine
삼항조건연산자
const solution = (a, b, c) =>
console.log(
a === b && b === c
? (a + b + c) *
(a ** 2 + b ** 2 + c ** 2) *
(a ** 3 + b ** 3 + c ** 3)
: a !== b && a !== c && b !== c
? a + b + c
: (a + b + c) * (a ** 2 + b ** 2 + c ** 2)
);
solution(2, 6, 1); // expected output: 9
solution(5, 3, 3); // expected output: 473
solution(4, 4, 4); // expected output: 110592
🔐 solution of others
if 조건문 const solution = (a, b, c) => {
let sum1 = a + b + c;
let sum2 = sum1 * (a ** 2 + b ** 2 + c ** 2);
let sum3 = sum2 * (a ** 3 + b ** 3 + c ** 3);
if (a == b && b == c) {
return console.log(sum3);
} else if (a == b || a == c || b == c) {
return console.log(sum2);
}
return console.log(sum1);
};
solution(2, 6, 1); // expected output: 9
solution(5, 3, 3); // expected output: 473
solution(4, 4, 4); // expected output: 110592
🔐 solution of others
new Set().size - 중복 제거
switch문
const solution = (a, b, c) => {
const set = new Set([a, b, c]).size;
switch (set) {
case 3:
return console.log(a + b + c);
case 2:
return console.log((a + b + c) * (a ** 2 + b ** 2 + c ** 2));
case 1:
return console.log(
(a + b + c) *
(a ** 2 + b ** 2 + c ** 2) *
(a ** 3 + b ** 3 + c ** 3)
);
}
return console.log();
};
solution(2, 6, 1); // expected output: 9
solution(5, 3, 3); // expected output: 473
solution(4, 4, 4); // expected output: 110592
🔐 solution of others
new Set() - 중복 제거
switch문
객체지향 프로그래밍
Math.pow()
const solution = (a, b, c) => {
const set = new Set([a, b, c]);
switch ([...set].length) {
case 1:
return calculate([a, b, c], 3);
case 2:
return calculate([a, b, c], 2);
case 3:
return calculate([a, b, c]);
}
};
const calculate = (inc, n = 1, answer = 1) => {
const [a, b, c] = inc;
for (let i = 1; i <= n; i++) {
answer *= Math.pow(a, i) + Math.pow(b, i) + Math.pow(c, i);
}
return console.log(answer);
};
solution(2, 6, 1); // expected output: 9
solution(5, 3, 3); // expected output: 473
solution(4, 4, 4); // expected output: 110592
와.. 진짜 엄청 어려웠는데, 공부하기 좋은 코드여땁
반응형