코딩테스트 문제 풀기 Lv 0 주사위 게임

휘루·2024년 6월 10일
0

코딩테스트

목록 보기
7/13

문제 설명

1부터 6까지 숫자가 적힌 주사위가 세 개 있습니다. 세 주사위를 굴렸을 때 나온 숫자를 각각 a, b, c라고 했을 때 얻는 점수는 다음과 같습니다.

세 숫자가 모두 다르다면 a + b + c 점을 얻습니다.
세 숫자 중 어느 두 숫자는 같고 나머지 다른 숫자는 다르다면 (a + b + c) × (a2 + b2 + c2 )점을 얻습니다.
세 숫자가 모두 같다면 (a + b + c) × (a2 + b2 + c2 ) × (a3 + b3 + c3 )점을 얻습니다.
세 정수 a, b, c가 매개변수로 주어질 때, 얻는 점수를 return 하는 solution 함수를 작성해 주세요.

제한사항

a, b, c는 1이상 6이하의 정수입니다.

입출력 예 설명

예제 1번에서 세 주사위 숫자가 모두 다르므로 2 + 6 + 1 = 9점을 얻습니다. 따라서 9를 return 합니다.
입출력 예 #2

예제 2번에서 두 주사위 숫자만 같으므로 (5 + 3 + 3) × (52 + 32 + 32 ) = 11 × 43 = 473점을 얻습니다. 따라서 473을 return 합니다.
입출력 예 #3

예제 3번에서 세 주사위 숫자가 모두 같으므로 (4 + 4 + 4) × (42 + 42 + 42 ) × (43 + 43 + 43 ) = 12 × 48 × 192 = 110,592점을 얻습니다. 따라서 110592를 return 합니다.

문제 풀이

function solution(a, b, c) {
    let answer = 0;
    
    let numA = (a + b + c);
    let numB = (a ** 2) + (b ** 2) + (c ** 2);
    let numC = (a ** 3) + (b ** 3) + (c ** 3);
    
    if (a !== b && b !== c && a !== c) {
        answer = (numA);
    } else if (a === b && b !== c || a !== b && b === c || a === c && a !== b || a !== c && a === b) {
	    answer = (numA) * (numB);
    } else if (a === b && b === c) {
        answer = (numA) * (numB) * (numC);
    }
    return answer;
}

문제 풀이 해석

풀어본 방법

  • if의 첫번째는 a와 b를 비교, b와 c를 비교, a와 c를 비교합니다.
    a, b, c가 모두 달라야 a + b + c를 얻을 수 있으니 a !== b, a !== c, b !== c를 비교합니다.

  • if의 두번째는
    a와 b가 같으면서 && b가 c와 다른지
    a와 b가 다르면서 && b와 c가 같은지

a와 c가 같으면서 && a와 b가 다른지
a와 c가 다르면서 && a와 b가 같은지

4가지의 경우를 비교했습니다.

  • if의 세번째는 a와 b가 같고 b와 c가 같은지를 비교합니다.

numA에 a + b + c를 저장
numB에 (a 2) + (b 2) + (c 2)를 저장
numC에 (a
3) + (b 3) + (c 3)를 저장합니다.

그리고 answer = 결과값으로 연산해 결과를 출력합니다.

다른 방법

다른 방법도 찾아와 가져 와봤습니다. 댓글이 제일 많았는데요.

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) => {
    const [a, b, c] = inc;
    let result = 1;
    for (let i = 1; i <= n; i++) {
        result *= Math.pow(a, i) + Math.pow(b, i) + Math.pow(c, i)
    }
    return result;
};
  • solution
    set을 객체로 만들어서 배열을 만듭니다.
    그 안에 switch를 동작해 [...set]으로 배열의 길이만큼 돌려서
    배열의 길이가 3이면 calc([a, b, c])를 호출
    배열의 길이가 2이면 calc([a, b, c], 2)를 호출
    배열의 길이가 1이면 calc([a, b, c], 1)을 호출합니다.
  • const calculate
    inc와 n = 1이라는 매개변수를 지정합니다. n의 기본 값은 1입니다.
    inc = [a, b, c]를 저장합니다.
    result는 1로 저장합니다.

for문을 돌려서 i <= n만큼 구동시켜서 i를 1씩 증가해 n만큼 구동 시킵니다.

result = result Math.pow(a, i) Math.pow(b, i) Math.pow(c, i);
a의 i만큼 제곱, b의 i만큼 제곱, c의 i만큼 제곱합니다.

return result;로 최종 계산된 result를 반환합니다.

profile
반가워요

0개의 댓글