🗃️javascript/프로그래머스

삼각형의 완성조건(1)(Lv.0) [sort(a,b)a-b :오름 차순 b-a : 내림차순]

하얀성 2022. 12. 28. 21:53
  •  
문제 설명

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

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

삼각형의 세 변의 길이가 담긴 배열 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();
    if (sides[0] + sides[1] > sides[2])
        return 1
    else
        return 2
}


<보충>

이런식으로 삼항연산자나 조건문들은 화살표함수와 같이 쓰지 않고 따로 독립적으로 써야하더라.

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

 

----> 근데 왜 sort()에 a,b를 추가하는 거지???????

 


https://celltong.tistory.com/entry/JavaScript-sort-%EB%A9%94%EC%86%8C%EB%93%9C%EB%A1%9C-%EB%B0%B0%EC%97%B4-%EC%A0%95%EB%A0%AC%ED%95%98%EA%B8%B0

 

JavaScript - 배열 오름차순, 내림차순 정렬하기 sort()

arr.sort() 배열을 재정렬해주는 메소드. 배열 자체가 변경되니까 사용시 주의해야함. let arr = [1, 5, 4, 2, 3]; arr.sort(); console.log(arr); // [1, 2, 3, 4, 5] > 오름차순으로 정렬 잘됨. let arr = ["a", "c", "d", "e", "b

celltong.tistory.com

여기 보면 이유가 나와 있음.

 

정리해보자면 정렬할 때 요소를 문자열로 취급해서.. 숫자의 비교가 아니라 문자 비교를 해서 순서가 뒤죽박죽됨


<보충2>

function solution(sides) {
    var answer = 0;
    const max = Math.max(...sides);
    const sum = sides.reduce((a,b) => a + b, 0) - max;

    answer = max < sum? 1 : 2;

    return answer;
}

이런식으로 max와 side operator를 이용해서 구하기도 하네... 와우!!

reduce((),(조건),초기값) ->> 맞나?? --> 조건이 아니라 결과네..(역시 아직 잘 모른다.)

 

배열.reduce((누적값, 현잿값, 인덱스, 요소) => { return 결과 }, 초깃값);