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

백승연·2023년 12월 19일
0

프로그래머스 - Lv. 0

목록 보기
19/60
post-thumbnail

🗒️ 문제

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

  • 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
    삼각형의 세 변의 길이가 담긴 배열 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합니다.

🖋️ 나의 풀이

function solution(sides) {
    sides.sort((a, b) => a - b);
    if (sides[0] + sides[1] <= sides[2]) {
        return 2;
    } else return 1;
}

💡 다른 사람들의 풀이

# 1

나도 삼항연산자 써볼걸..

function solution(sides) {
    sides = sides.sort((a,b) => a-b)
    return sides[0]+sides[1] > sides[2] ? 1 : 2;
}

# 2

구조분해할당을 사용한 풀이

function solution(sides) {
    const [long, a, b] = sides.sort((a,b) => b-a);
    return long < a + b ? 1 : 2
}



📝 모르는 내용 찾아보기

구조 분해 할당

구조 분해 할당은 배웠던건데 잘 기억이 안 나서 다시 정리해본다.

구조 분해 할당이란 배열이나 객체의 속성을 해체하여 그 값을 개별 변수에 담을 수 있게 하는 javascript 표현식이다. 간단하게 말하면 분해하여 다른 변수에 담을 수 있게 해주는 것

1. 배열에서의 구조 분해 할당 사용 방법

#1

const arr = [1, 2, 3, 4];

const a = arr[0];
const b = arr[1];

console.log(a); // 1
console.log(b); // 2

#2

const arr = [1, 2, 3, 4];

const [a, b] = arr;

console.log(a); // 1
console.log(b); // 2

#3

const [a, b, c = 3] = [1, 2];

console.log(a); // 1
console.log(b); // 2
console.log(c); // 3 -> 만약 기본값을 지정해주지 않았다면 undefined 출력

profile
공부하는 벨로그

0개의 댓글