n보다 커질 때까지 더하기

프로그래머스 n보다 커질 때까지 더하기

문제

정수 배열 numbers와 정수 n이 매개변수로 주어집니다. numbers의 원소를 앞에서부터 하나씩 더하다가 그 합이 n보다 커지는 순간 이때까지 더했던 원소들의 합을 return 하는 solution 함수를 작성해 주세요.

제한 사항

  • 1 ≤ numbers의 길이 ≤ 100
  • 1 ≤ numbers의 원소 ≤ 100
  • 0 ≤ n < numbers의 모든 원소의 합

예시

입출력 예 #1

  • 예제 1번의 numbers를 문제 설명대로 더해가는 과정을 나타내면 다음의 표와 같습니다.
inumbers[i]sum
  0
03434
1539
271110
329139

29를 더한 뒤에 sum 값은 139이고 'n' 값인 123보다 크므로 139를 return 합니다.

  • 예제 2번의 numbers의 마지막 원소 전까지의 원소를 sum에 더하면 139입니다. 139는 n 값인 139보다 크지 않고 마지막 원소인 100을 더하면 139보다 커지므로 239를 return 합니다.

풀이

  • JavaScript
function solution(numbers, n) {
    var answer = 0;
    for (let i = 0; i < numbers.length; i++) {
        answer += numbers[i]
        
        if (answer > n) break
    }
    return answer;
}
  • python
def solution(numbers, n):
    answer = 0
    for num in numbers:
        answer += num
        if answer > n:
            break
    return answer
* TOC {:toc}

© 2021. All rights reserved.