[프로그래머스 / lv0] 삼각형의 완성조건(1)
in Development on Algorithm
문제
문제 설명
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
- 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 세 변의 길이가 담긴 배열 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 |
입출력 예 설명
입출력 예 #1
- 가장 큰 변인 3이 나머지 두 변의 합 3과 같으므로 삼각형을 완성할 수 없습니다. 따라서 2를 return합니다.
입출력 예 #2
- 가장 큰 변인 6이 나머지 두 변의 합 5보다 크므로 삼각형을 완성할 수 없습니다. 따라서 2를 return합니다.
입출력 예 #3
- 가장 큰 변인 222가 나머지 두 변의 합 271보다 작으므로 삼각형을 완성할 수 있습니다. 따라서 1을 return합니다.
풀이 & 걸린시간
- 걸린시간: 11m 09s
- 풀이
function solution(sides) {
var answer = 0;
function compare(a, b) {
if (a > b) return 1;
if (a < b) return -1;
return 0;
}
sides.sort(compare);
return sides[2] < sides[0] + sides[1] ? 1 : 2;
}
느낀 점
나는 인덱스값을 하나하나 비교해서 제일 큰 값을 변수에 담아두고 나머지 두 인덱스 값을 가져와서 값을 비교하려고 했다. 근데 이 방법이 생각보다 비 효율적이라고 생각이 들어 sort함수를 써서 정렬을 이용하면 어떨까라고 생각하게 되었다. 솔직히 아직 sort는 잘 사용하지 않아서 미숙한 부분이 있었는데 정렬을 통해 값을 비교하니 수월하게 진행되었다.
이번에 하면서 가장 많이 느낀 부분이 sort는 정렬할때 많이 사용되는데 나는 정렬을 잘 사용하지 않고 있는 것이었다. 그리고 javascript의 기초가 좀 많이 부족하다는 생각을 하여 이번 주말에 계획을 세우고 하나씩 개념 및 사용법을 익힐 예정이다.