-
[Programmers] JavaScript 알고리즘 | Lv.0 주사위 게임 2► JS Algorithm/Programmers 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
와.. 진짜 엄청 어려웠는데, 공부하기 좋은 코드여땁
반응형'► JS Algorithm > Programmers' 카테고리의 다른 글
[Programmers] JavaScript 알고리즘 | Lv.0 문자열 잘라서 정렬하기 (0) 2024.01.16 [Programmers] JavaScript 알고리즘 | Lv.0 수 조작하기 2 (0) 2024.01.16 [Programmers] JavaScript 알고리즘 | Lv.0 문자열 섞기 (0) 2024.01.15 [Programmers] JavaScript 알고리즘 | Lv.0 간단한 식 계산하기 (0) 2024.01.15 [Programmers] JavaScript 알고리즘 | Lv.0 숫자 찾기 (0) 2024.01.12