티스토리 뷰
문제 설명
Finn은 요즘 수학공부에 빠져 있습니다. 수학 공부를 하던 Finn은 자연수 n을 연속한 자연수들로 표현 하는 방법이 여러개라는 사실을 알게 되었습니다. 예를들어 15는 다음과 같이 4가지로 표현 할 수 있습니다.
- 1 + 2 + 3 + 4 + 5 = 15
- 4 + 5 + 6 = 15
- 7 + 8 = 15
- 15 = 15
자연수 n이 매개변수로 주어질 때, 연속된 자연수들로 n을 표현하는 방법의 수를 return하는 solution를 완성해주세요.
제한사항
n은 10,000 이하의 자연수 입니다.
입출력 예
n | result |
---|---|
15 | 4 |
입출력 예 설명
입출력 예#1
문제의 예시와 같습니다.
접근
처음엔 규칙성이 있을까하고 n을 1일 때, 2일 때 등 상황을 가정해봤는데 규칙성이 보이지 않았다. 규칙성을 갖고 푸는 문제가 아니었다.
그래서 반복문과 조건분기로 풀기로 하고 1부터 n까지의 숫자를 준비했다.
1+2+3+ ... +n의 과정중에 합이 n이 되거나 n보다 값이 커지면 반복문이 종료되고 다시 2부터(그 다음 숫자부터) n까지 합을 구하는 과정을 반복했다.
구현
const solution = n => {
let answer = 0;
// 1~n까지의 수
const arr = Array(n).fill(1).map((v, i) => v + i);
// 연속한 자연수들의 시작 인덱스
let start = 0;
// 인덱스는 주어진 수-1까지 존재
while (start < n) {
// 연속한 자연수의 합
let sum = 0;
for (let i = start; i < arr.length; i++) {
sum += arr[i];
// 연속한 자연수의 합이 n이 되면 answer ++하고 종료
if (sum === n) {
answer++;
break;
}
// 연속한 자연수의 합이 n보다 커지면 종료
if (sum > n) {
break;
}
}
start++;
}
return answer;
};
반응형
'프로그래머스 문제풀이 > Level 2' 카테고리의 다른 글
[프로그래머스 Lv 2] 가장 큰 수 (0) | 2020.05.03 |
---|---|
[프로그래머스 Lv 2] JadenCase 문자열 만들기 (0) | 2020.05.02 |
[프로그래머스 Lv 2] N개의 최소공배수 (0) | 2020.05.01 |
[프로그래머스 Lv 2] 예상 대진표 (0) | 2020.04.30 |
[프로그래머스 Lv 2] 기능개발 (0) | 2020.04.29 |
댓글