다음과 같은 숫자 배열이 있다고 가정합니다. -
const arr = [1,2,3,4,1,7,8,9,1];
배열에서 가장 작은 요소의 인덱스, 즉 위의 1을 찾고 싶다고 가정합니다.
이를 위해 간단히 −
를 사용할 수 있습니다.const min = Math.min.apply(Math, arr); const ind = arr.indexOf(min);
위의 코드는 ind를 0으로 성공적으로 설정하며 이는 실제로 정확합니다.
그러나 우리가 달성하고자 하는 것은 위의 배열(3개의 1)과 같이 배열에 둘 이상의 최소 요소가 있는 경우 최소 요소의 모든 인덱스를 포함하는 배열을 반환해야 한다는 것입니다.
따라서 이 배열의 경우 원하는 출력은 다음과 같습니다. 즉, 인덱스 0, 4 및 8에서 3개의 1이 발견됩니다. -
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 ]