色婷婷狠狠18禁久久YY,CHINESE性内射高清国产,国产女人18毛片水真多1,国产AV在线观看

javascript中求二維數組最小值

周世慧1年前6瀏覽0評論

在JavaScript中,求二維數組最小值是一項常見的任務。二維數組是由多個一維數組組成的數據結構,其中每個一維數組可以看作二維數組的一個行或列。如果要獲取整個二維數組中最小的元素,就需要遍歷每一個元素,并且將最小值不斷地更新。

假設我們有以下的二維數組:

[
[3, 4, 5],
[1, 7, 2],
[9, 8, 6]
]

我們可以先將第一個元素作為目前的最小值,然后逐一遍歷所有元素,將最小值與當前元素進行比較,如果當前元素比最小值還小,則將最小值更新為當前元素。示例代碼如下:

function getMin(arr) {
let min = arr[0][0];
for(let i = 0; i < arr.length; i++) {
for(let j = 0; j < arr[i].length; j++) {
if(arr[i][j] < min) {
min = arr[i][j];
}
}
}
return min;
}
let arr = [
[3, 4, 5],
[1, 7, 2],
[9, 8, 6]
];
console.log(getMin(arr));  // 1

上面的代碼中,我們使用了兩個循環遍歷了整個二維數組,因此時間復雜度較高。如果我們想要提高效率,可以使用一種基于reduce函數的方法。reduce函數可以將數組中的一個復雜操作簡化為一行代碼,一般的操作包括求和、過濾、排序等。

對于求二維數組最小值,reduce函數可以這樣使用:

function getMin(arr) {
return arr.reduce((prev, curr) => {
return Math.min(prev, ...curr);
});
}
let arr = [
[3, 4, 5],
[1, 7, 2],
[9, 8, 6]
];
console.log(getMin(arr));  // 1

上面的代碼中,reduce函數的第一個參數是一個函數,這個函數接受兩個參數:prev代表當前的最小值,curr代表當前的一維數組。我們使用了ES6的展開語法(...curr)將一維數組展開成一組參數傳入Math.min函數中,這樣就可以輕松地求出當前一維數組中的最小值。當所有一維數組都執行完畢后,reduce函數會返回整個二維數組中的最小值。

綜上所述,求二維數組最小值是一項非?;A的任務,在JavaScript中我們可以通過循環或者reduce函數來實現。reduce函數可以將代碼更加簡化、可讀、易維護,因此建議在實際開發中優先考慮使用reduce函數。