문제
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
- 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.
제한사항
- sides 의 원소는 자연수 입니다.
- sides 의 길이는 3입니다.
- 1 ≤ sides 의 원소 ≤ 1,000
import java.util.*;
class Solution {
public int solution(int[] sides) {
int answer = 0;
Arrays.sort(sides);
return sides[2] >= sides[0]+sides[1] ? 2 : 1;
}
}
문득 Arrays.sort()와 Collections.sort()의 차이점이 궁금해졌다.
둘이 다른 정렬방식을 사용한다고 한다.
이해하기엔 좀 더 찾아봐야하겠지만, 일단 둘의 시간복잡도는 최악의 기준으로
Arrays.sort() -> O(n^2)
Collections.sort() -> O(nlog(n)) 이라고 한다.