https://school.programmers.co.kr/learn/courses/30/lessons/120889
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
■ 문제 설명
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
- 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.
■ 제한사항
- sides의 원소는 자연수입니다.
- sides의 길이는 3입니다.
- 1 ≤ sides의 원소 ≤ 1,000
■ 나의 코드
class Solution {
public int solution(int[] sides) {
int answer = 2, max = 0, sum = 0;
for(int i=0; i<sides.length; i++) {
sum += sides[i];
if(max < sides[i])
max = sides[i];
}
if(max < sum-max)
answer = 1;
return answer;
}
}
■ 코드 해설
answer의 초기값을 2로 주었고, sum에 sides의 값을 누적해 max와 비교 후 sides값이 더 크다면 max에 sides값을 넣었습니다. 그 후 max(가장 긴 변의 길이)가 다른 두 변의 길이(sum-max, 전체의 값에 max 제외)보다 작다면 (삼각형이 만들어지는 조건) answer의 값을 1로 변경했습니다.