<문제>
정수 배열 numbers와 정수 n이 매개변수로 주어집니다. numbers의 원소를 앞에서부터 하나씩 더하다가 그 합이 n보다 커지는 순간 이때까지 더했던 원소들의 합을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 ≤ numbers의 길이 ≤ 100
- 1 ≤ numbers의 원소 ≤ 100
- 0 ≤ n < numbers의 모든 원소의 합
입출력 예numbersnresult
[34, 5, 71, 29, 100, 34] | 123 | 139 |
[58, 44, 27, 10, 100] | 139 | 239 |
입출력 예 설명
입출력 예 #1
- 예제 1번의 numbers를 문제 설명대로 더해가는 과정을 나타내면 다음의 표와 같습니다.inumbers[i]sum
0 0 34 34 1 5 39 2 71 110 3 29 139 - 예제 2번의 numbers의 마지막 원소 전까지의 원소를 sum에 더하면 139입니다. 139는 n 값인 139보다 크지 않고 마지막 원소인 100을 더하면 139보다 커지므로 239를 return 합니다.
<제출답안>
function solution(numbers, n) {
let sum = 0;
let answer = null;
numbers.some(x=>{sum += x; if(sum > n ){ answer = sum; return true; } })
return answer
}
여태껏 함수 안에 함수를 넣거나 함수 안에 절을 넣는걸 못한 이유.
1. 절도 return문을 낼 수 있고 감싼다는 사실을 인지는 하되 적용은 할줄 모르고. 그걸 함수로 감쌀 줄도 모르고 ㅎㅎ
내가 만든 함수가 아니라 기존 메서드 함수이기 때문에 return문은 적으면 오히려 에러가 뜬다 것도 알고 넘어가자.
2. ; 기호를 안쓰고 그냥 띄워쓰기 하고 다음글을 써서 에러
3. 개념 이해도 부족. 아래의 글을 찬찬히 다 읽어보자
'🗃️javascript > 프로그래머스' 카테고리의 다른 글
폰켓몬(Lv.1)[해시의 개념을 생각해보고, 단순히 구현하자] (0) | 2023.06.20 |
---|---|
K번째수(Lv.1)[sort()는 문자정렬임. 숫자 정렬도 문자열 정렬로 취급] (0) | 2023.06.20 |
길이에 따른 연산(LV.0)[reduce((현재값, 누적공간, 인덱스)=> 식, 초기값)] (0) | 2023.06.10 |
n 번째 원소까지(Lv.0)[다시 코테연습 시작] (0) | 2023.06.09 |
문자열 밀기(Lv.0) (0) | 2023.04.10 |