ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [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

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


     

    반응형
Designed by Tistory.