► 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

와.. 진짜 엄청 어려웠는데, 공부하기 좋은 코드여땁


 

반응형