[Programmers algorithm] 삼각형의 완성조건 (1)

2023. 6. 20. 20:22알고리즘

1. 문제설명

🔊 선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.

  • 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.

삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.

[ 제한조건 ]

  • sides의 원소는 자연수입니다.
  • sides의 길이는 3입니다.
  • 1 ≤ sides의 원소 ≤ 1,000

[ 입출력예시 ]

sides result
[1, 2, 3] 2
[3, 6, 2] 2
[199, 72, 222] 1

[ 답안 포맷 ]

function solution(sides) {
    var answer = 0;
    return answer;
}

2. 문제풀이

const solution = (sides) => {
  // sides를 오름차순으로 정렬한다.
  const sort = sides.sort((a, b) => a - b);
  const longSide = sort[2]; // 가장 긴 변
  const twoSides = sort[0] + sort[1]; // 나머지 두변의 합

  // 두변의 합이 긴 변보다 크면 1을 리턴
  if (twoSides > longSide) return 1;

  // 아니면, 2를 리턴
  return 2;
};