[프로그래머스] n보다 커질 때까지 더하기
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · n보다 커질 때까지 더하기 · js n보다 커질 때까지 더하기
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · n보다 커질 때까지 더하기 · js n보다 커질 때까지 더하기
문제 설명
정수 배열 numbers
와 정수 n
이 매개변수로 주어집니다. numbers
의 원소를 앞에서부터 하나씩 더하다가 그 합이 n
보다 커지는 순간 이때까지 더했던 원소들의 합을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 ≤
numbers
의 길이 ≤ 100 - 1 ≤
numbers
의 원소 ≤ 100 - 0 ≤ n <
numbers
의 모든 원소의 합
입출력 예
numbers | n | result |
---|---|---|
[34, 5, 71, 29, 100, 34] | 123 | 139 |
[58, 44, 27, 10, 100] | 139 | 239 |
입출력 예 설명
입출력 예 #1
- 예제 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 합니다. - 예제 2번의
numbers
의 마지막 원소 전까지의 원소를 sum에 더하면 139입니다. 139는n
값인 139보다 크지 않고 마지막 원소인 100을 더하면 139보다 커지므로 239를 return 합니다.
나의 풀이
function solution(numbers, n) {
var answer = numbers.reduce((acc, cur) => (acc > n ? acc : acc + cur), 0);
return answer;
}
나의 두번째 풀이(Code Refactoring)
function solution(numbers, n) {
let result = 0;
for (i = 0; i < numbers.length; i++) {
result += numbers[i];
if (result > n) break;
}
return result;
}
참고 할 만한 다른 사람의 코드
function solution(numbers, n) {
var answer = 0;
let i = 0;
while (answer <= n) {
answer += numbers[i++];
}
return answer;
}