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가지의 경우를 비교했습니다.
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;
};
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를 반환합니다.