프로그래머스 JS LV0
LV0 76 삼각형의 완성조건(2)
와라리요
2022. 11. 11. 12:59
문제 설명
선분 세 개로 삼각형을 만들기 위해서는 다음과 같은 조건을 만족해야 합니다.
- 가장 긴 변의 길이는 다른 두 변의 길이의 합보다 작아야 합니다.
삼각형의 두 변의 길이가 담긴 배열 sides이 매개변수로 주어집니다. 나머지 한 변이 될 수 있는 정수의 개수를 return하도록 solution 함수를 완성해주세요.
제한 사항
- sides의 원소는 자연수입니다.
- sides의 길이는 2입니다.
- 1 ≤ sides의 원소 ≤ 1,000
입출력 예
sides | result |
[1, 2] | 1 |
[3, 6] | 5 |
[11, 7] | 13 |
나만의 풀이
이 문제는 처음에는 for문을 이용하여 문제를 풀었다. 먼저 이 문제는 큰 수에 포커스를 맞추어 문제를 진행해야 하는데 sides 매개변수 배열 중 큰 숫자의 index가 어딘지 모르느 sort()를 이용해 내림차순으로 정렬하고 가시적으로 보기 좋게 const를 이용해 배열의 큰 수, 작은 수를 선언했다.
그 후 for문와 삼항연산자를 이용해 해당 조건이 되면 count라는 변수에 ++하는 형태로 풀었다~~
function solution(sides) {
const numArr = sides.sort((a, b) => a - b)
const Arr0 = numArr[0]
const Arr1 = numArr[1]
let count = 0;
for (let i = 1; i <= Arr1; i++) {
Arr1 < Arr0 + i ? count++ : null;
}
for (let i = 1; i < Arr0 + Arr1; i++) {
Arr1 < i ? count++ : null;
}
return count
}
그런데 문제를 보면 볼 수록 count 값을 구하는데 규칙이 있는 것으로 보여 보는 중
(Arr1 - (Arr1 - Arr0)) + (Arr1 + Arr0 - Arr1 - 1)의 식을 만들면 출력하고자 하는 값이 나온다는 규칙을 찾아서 코드를 새롭게 구성해 보았다.
function solution(sides) {
const numArr = sides.sort((a, b) => a - b)
const Arr0 = numArr[0]
const Arr1 = numArr[1]
return (Arr1 - (Arr1 - Arr0)) + (Arr1 + Arr0 - Arr1 - 1)
}