티스토리 뷰

문제 설명

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;
};
반응형
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
TAG
more
«   2025/07   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31
글 보관함