logo
Posts프로그래머스삼각형의 완성조건 (1)

삼각형의 완성조건 (1)

문제 설명

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

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

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

제한 사항

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

입출력 예

sidesresult
[1, 2, 3]2
[3, 6, 2]2
[199, 72, 222]1

입출력 예 설명

입출력 예 #1

  • 가장 큰 변인 3이 나머지 두 변의 합 3과 같으므로 삼각형을 완성할 수 없습니다. 따라서 2를 return합니다.

입출력 예 #2

  • 가장 큰 변인 6이 나머지 두 변의 합 5보다 크므로 삼각형을 완성할 수 없습니다. 따라서 2를 return합니다.

입출력 예 #3

  • 가장 큰 변인 222가 나머지 두 변의 합 271보다 작으므로 삼각형을 완성할 수 있습니다. 따라서 1을 return합니다.

문제풀이 (나)

function solution(sides) {
    const [a, b, c] = sides.sort((a, b) => a - b);
    return a + b > c ? 1 : 2;
}
  • 어제 점의 위치 구하기를 하다가, 구조분해에 대해 알게 되어서 간단하게 할 수 있었다.
  1. 배열 sides를 먼저 sort 해준다.
  2. 이때 주의할 점은, sort 의 경우 ASCII 문자열이라고 생각하고 정렬한다.
  • 따라서 숫자를 기준으로 sort 하게 해주어야 하는데, MDN 에 자세히 나와 있다.
  • MDN에서는 sort 메서드 파라미터로 정렬 순서를 정의하는 함수, compareFunction가 들어간다.
  • compareFunction(a, b)이 음수일 경우, a가 먼저 오도록 한다.
  • compareFunction(a, b)이 0일 경우, 그대로 유지한다.
  • compareFunction(a, b)이 양수일 경우, a를 뒤로 보낸다.
  • 숫자를 비교하기 위해 compare 함수는 a에서 b를 뺄 수 있다.
  • a - b 일 경우, 오름차순으로 정렬한다.
  • b - a 일 경우, 내림차순으로 정렬한다.
  1. 배열 sides를 각각 변수 a, b, c 에 할당해준다.
  2. 변수 중 c 가 가장 큰 숫자이니, 가장 긴 변에 해당한다.
  3. 문제대로 가장 긴 변의 길이가 다른 두 변의 길이의 합보다 작은지 확인하고 요청한 값을 리턴한다.

문제풀이 (다른사람)

function solution(sides) {
    sides = sides.sort((a,b) => a-b)
    return sides[0]+sides[1] > sides[2] ? 1 : 2;
}
  • 가장 많은 좋아요를 받은 사람의 풀이를 가져왔다.
  1. 나랑 비슷하게 한 것 같다.

레퍼런스