
정수 배열 numbers와 정수 n이 매개변수로 주어집니다. numbers의 원소를 앞에서부터 하나씩 더하다가 그 합이 n보다 커지는 순간 이때까지 더했던 원소들의 합을 return 하는 solution 함수를 작성해 주세요.
numbers의 길이 ≤ 100numbers의 원소 ≤ 100numbers의 모든 원소의 합| numbers | n | result |
|---|---|---|
| [34, 5, 71, 29, 100, 34] | 123 | 139 |
| [58, 44, 27, 10, 100] | 139 | 239 |
입출력 예 #1
numbers를 문제 설명대로 더해가는 과정을 나타내면 다음의 표와 같습니다.| i | numbers[i] | sum |
|---|---|---|
| 0 | ||
| 0 | 34 | 34 |
| 1 | 5 | 39 |
| 2 | 71 | 110 |
| 3 | 29 | 139 |
29를 더한 뒤에 sum 값은 139이고 n 값인 123보다 크므로 139를 return 합니다.
numbers의 마지막 원소 전까지의 원소를 sum에 더하면 139입니다. 139는 n 값인 139보다 크지 않고 마지막 원소인 100을 더하면 139보다 커지므로 239를 return 합니다.function solution(numbers, n) {
let sum = 0; // 합을 저장할 변수 초기화
let i = 0; // 배열 인덱스 초기화
while (sum <= n && i < numbers.length) {
sum += numbers[i]; // 현재 원소를 합산
i++; // 다음 인덱스로 이동
}
return sum; // 합이 n보다 커졌을 때의 합 반환
}
sum: numbers 배열의 원소들을 누적하여 저장할 변수로 초기값은 0입니다.i: 배열의 현재 인덱스를 추적하는 변수로 초기값은 0입니다.while 조건:sum <= n: 합이 아직 n보다 작거나 같은 경우 반복을 계속합니다.i < numbers.length: 배열을 초과하지 않도록 범위를 제한합니다.sum += numbers[i]: 현재 인덱스의 값을 sum에 추가합니다.i++: 인덱스를 다음 위치로 이동합니다.while문이 종료되는 시점에서 sum은 n보다 큰 값이 되어 있으므로 이를 반환합니다.