코딩테스트

프로그래머스_삼각형의 완성조건(1)

코딩기계 2024. 3. 25. 17:58

문제 설명

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

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

삼각형의 세 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 세 변으로 삼각형을 만들 수 있다면 1, 만들 수 없다면 2를 return하도록 solution 함수를 완성해주세요.


제한사항
  • sides의 원소는 자연수입니다.
  • sides의 길이는 3입니다.
  • 1 ≤ sides의 원소 ≤ 1,000

입출력 예sidesresult
[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합니다.

문제풀이:(펼치기)

더보기
#include <string>
#include <vector>
#include <algorithm>

using namespace std;

int solution(vector<int> sides) {
    // 변의 길이를 오름차순으로 정렬
    
    sort(sides.begin(), sides.end());

    // 가장 긴 변
    
    int longest_side = sides[2];
    
    // 나머지 두 변의 합
    
    int sum_of_other_sides = sides[0] + sides[1];

    // 삼각형을 만들 수 있는지 여부 판별
    if (longest_side < sum_of_other_sides) 
        return 1;
     else 
        return 2;
    
}

 

푸는도중 느낀점: 알고리즘의 기능을 잘사용하자.

sort정렬!