본문 바로가기
코딩테스트/자바 Level 0

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

by onggury 2023. 7. 6.

문제

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

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

삼각형의 세 변의 길이가 담긴 배열 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)) 이라고 한다.