다음과 같은 숫자 배열이 있다고 가정해 보겠습니다. -
const arr = [1,2,3,4,1,7,8,9,1];
배열에서 가장 작은 요소의 인덱스를 찾고 싶다고 가정합니다. 이를 위해 간단히 −
를 사용할 수 있습니다.const min = Math.min.apply(Math, arr); const ind = arr.indexOf(min);
이 코드는 ind를 0으로 성공적으로 설정하며 이는 실제로 정확합니다.
그러나 우리가 달성하고자 하는 것은 위의 배열(3개)과 같이 배열에 최소 요소가 두 개 이상 있는 경우 최소 요소의 모든 인덱스를 포함하는 배열을 반환해야 한다는 것입니다.
따라서 이 배열의 경우 원하는 출력은 -
입니다.const ind = [0, 4, 8]
숫자 배열을 받아 배열에 있는 최소 요소의 모든 인덱스를 반환하는 JavaScript 함수를 작성해야 합니다.
따라서 이 함수의 코드를 작성해 보겠습니다 -
예시
이에 대한 코드는 -
const arr = [1,2,3,4,1,7,8,9,1]; const minArray = arr => { const min = arr.reduce((acc, val) => Math.min(acc, val), Infinity); const res = []; for(let i = 0; i < arr.length; i++){ if(arr[i] !== min){ continue; }; res.push(i); }; return res; }; console.log(minArray(arr));
출력
콘솔의 출력은 다음과 같습니다. -
[ 0, 4, 8 ]