본문 바로가기

프로그래머스 코딩(자바)/Level 0

Programmers Level 0 - 삼각형의 완성조건 (1)

728x90
    문제 설명

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

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

    삼각형의 세 변의 길이가 담긴 배열 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합니다.
    1
    2
    3
    4
    5
    6
    7
    import java.util.Arrays;
    class Solution {
        public int solution(int[] sides) {
           Arrays.sort(sides);        
           return sides[2]<sides[0]+sides[1] ? 1 : 2;
        }
    }
     
    cs

     

     문제에 답이있다.

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

    그렇다면 배열을 오름차순 정렬하면 변의 길이가 적은것 부터 큰것이 차례대로 배열될 것이다.
    Arrays.sort(sides);

    제일 긴것이 sides[2] 에 중간 것이 sides[1] 에 제일 적은것이 sides[0] 에 있게된다.

    그래서 3항 연산자를 이용하여 조건에 만족하면 1을 아니면 2를 리턴한다.
    return sides[2]<sides[0]+sides[1] ? 1 : 2;

    728x90