[문제]
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
(조건) 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.
[입출력 예]
sides | result |
[1, 2, 3] | 2 |
[3, 6, 2] | 2 |
[199, 72, 222] | 1 |
[Solution.java]
class Solution {
public int solution(int[] sides) {
// 배열을 순회하면서 크기 비교 후 두 값 교환 (제일 큰 값이 제일 마지막 인덱스로 오도록)
// 삼각형의 완성 조건으로 인해 max값 하나만 마지막으로 가면 되기 때문에 크기 순서대로 정렬할 필요는 없음
for(int i = 0; i<sides.length-1; i++){
if(sides[i]>sides[i+1]){
int tmp = 0;
tmp = sides[i];
sides[i] = sides[i+1];
sides[i+1] = tmp;
}
}
// 문제 조건 이용 (가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작다)
if(sides[2]>=sides[0]+sides[1]) return 2;
else return 1;
}
}
'알고리즘 연습 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 숨어있는 숫자의 덧셈(1) - 문자열 숫자로 변환(Integer.parseInt) (0) | 2023.06.17 |
---|---|
[프로그래머스] 배열의 유사도 (문자열 비교는 equals 이용) (1) | 2023.06.16 |