문제
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
- 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 두 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 나머지 한 변이 될 수 있는 정수의 개수를 return하도록 solution 함수를 완성해주세요.
제한사항
- sides 의 원소는 자연수입니다.
- sides 의 길이는 2입니다.
- 1 ≤ sides 의 원소 ≤ 1,000
import java.util.*;
class Solution {
public int solution(int[] sides) {
int answer = 0;
Arrays.sort(sides);
for(int i = sides[1]-sides[0]+1; i <= sides[1]; i++) {
answer++;
}
answer += sides[0] - 1;
return answer;
}
}
처음 for문은 가장 긴 변의 길이가 배열 sides의 원소 중 큰 값인 경우를 계산했다.
그리고 for문을 빠져나와서 answer += sides[0]-1 은 주어진 배열 sides 말고 더 긴 변이 존재할 경우이고,
sides[1] - (sides[1] + sides[0]) - 1 의 식을 정리한 것이다.
긴 변의 길이 - (긴 변의 길이 + 짧은 변의 길이) - 1
출처
https://school.programmers.co.kr/learn/courses/30/lessons/120868