다음과 같은 정수 배열이 있다고 가정합니다. -
const arr = [12, 1, 4, 8, 5];
이러한 배열을 유일한 인수로 취하는 JavaScript 함수를 작성해야 합니다.
그러면 함수는 정확히 두 개의 정수 배열을 반환해야 합니다. -
-
첫 번째 정수는 한 요소를 제외한 모든 배열 요소의 가능한 가장 작은 합이어야 합니다.
-
두 번째 정수는 한 요소를 제외한 모든 배열 요소의 가능한 최대 합이어야 합니다.
우리를 위한 유일한 조건은 하나의 for 루프를 사용하여 이 작업을 수행해야 한다는 것입니다.
예를 들어 -
위 배열의 경우 출력은 -
여야 합니다.const output = [18, 29];
제외된 숫자는 각각 12와 1이기 때문입니다.
예시
이에 대한 코드는 -
const arr = [12, 1, 4, 8, 5];
const findExtremeNumbers = (arr = []) => {
let sum = 0;
let min = Infinity;
let max = -Infinity;
for(let i = 0; i < arr.length; i++){
const curr = arr[i];
sum += curr;
if(curr > max){
max = curr;
}
if(curr < min){
min = curr;
};
};
return [sum - max, sum - min];
};
console.log(findExtremeNumbers(arr)); 출력
콘솔의 출력은 -
[18, 29]