JavaScript學(xué)習(xí)筆記之取數(shù)組中最大值和最小值
來(lái)源:易賢網(wǎng) 閱讀:989 次 日期:2016-07-16 14:32:48
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript學(xué)習(xí)筆記之取數(shù)組中最大值和最小值”,方便廣大網(wǎng)友查閱!

在實(shí)際業(yè)務(wù)中有的時(shí)候要取出數(shù)組中的最大值或最小值。但在數(shù)組中并沒(méi)有提供arr.max()和arr.min()這樣的方法。那么是不是可以通過(guò)別的方式實(shí)現(xiàn)類(lèi)似這樣的方法呢?那么今天我們就來(lái)整理取出數(shù)組中最大值和最小值的一些方法。

取數(shù)組中最大值

可以先把思路理一下:

將數(shù)組中第一個(gè)元素賦值給一個(gè)變量,并且把這個(gè)變量作為最大值;

開(kāi)始遍歷數(shù)組,從第二個(gè)元素開(kāi)始依次和第一個(gè)元素進(jìn)行比較

如果當(dāng)前的元素大于當(dāng)前的最大值,就把當(dāng)前的元素值賦值給最大值

移動(dòng)到下一個(gè)元素,繼續(xù)按前面一步操作

當(dāng)數(shù)組元素遍歷結(jié)束時(shí),這個(gè)變量存儲(chǔ)的就是最大值

代碼如下:

Array.prototype.max = function () {

// 將數(shù)組第一個(gè)元素的值賦給max

var max = this[0];

// 使用for 循環(huán)從數(shù)組第一個(gè)值開(kāi)始做遍歷

for (var i = 1; i < this.length; i++) {

// 如果元素當(dāng)前值大于max,就把這個(gè)當(dāng)前值賦值給max

if (this[i] > max) {

max = this[i];

}

}

// 返回最大的值

return max;

}

來(lái)看一個(gè)示例:

var arr = [1,45,23,3,6,2,7,234,56];

arr.max(); // 234

上面的示例,數(shù)組中都是數(shù)值,那么如果數(shù)組中不全是數(shù)值會(huì)是一個(gè)什么樣的效果呢?來(lái)測(cè)試一下先:

var arr = [1,45,23,3,6,2,7,234,56,'2345','a','c'];

arr.max(); // 'c'

這并不是我們想要的結(jié)果吧。(此處跪求解決方案)

通過(guò)前段時(shí)間的學(xué)習(xí),都知道for循環(huán)性能要比f(wàn)orEach()差,那可以將上面的方法改成forEach()方法:

Array.prototype.max = function (){

var max = this[0];

this.forEach (function(ele,index,arr){

if(ele > max) {

max = ele;

}

})

return max;

}

var arr = [1,45,23,3,6,2,7,234,56];

arr.max(); // 234

取數(shù)組中最小值

類(lèi)似取最大值的思路一樣,我們可以很輕松的實(shí)現(xiàn)arr.min()方法,取出數(shù)組中的最小值:

Array.prototype.min = function () {

var min = this[0];

this.forEach(function(ele, index,arr) {

if(ele < min) {

min = ele;

}

})

return min;

}

var arr = [1,45,23,3,6,2,7,234,56];

arr.min(); // 1

其他方法

除了上面的方案,還可以有其他方法,比如使用數(shù)組的reduce()方法。回憶前面的學(xué)過(guò)的知識(shí),reduce()方法可以接收一個(gè)回調(diào)函數(shù)callbackfn,可以在這個(gè)回調(diào)函數(shù)中拿數(shù)組中的初始值(preValue)與數(shù)組中當(dāng)前被處理的數(shù)組項(xiàng)(curValue)做比較,如果preValue大于curValue值返回preValue,反之返回curValue值,依此類(lèi)推取出數(shù)組中最大值:

Array.prototype.max = function() {

return this.reduce(function(preValue, curValue,index,array) {

return preValue > curValue ? preValue : curValue;

})

}

var arr = [1,45,23,3,6,2,7,234,56];

arr.max(); // 234

同樣的也可以使用類(lèi)似的方法實(shí)現(xiàn)arr.mix()方法,取出數(shù)組中的最小值:

Array.prototype.min = function() {

return this.reduce(function(preValue, curValue,index,array) {

return preValue > curValue ? curValue : preValue;

})

}

var arr = [1,45,23,3,6,2,7,234,56];

arr.min(); // 1

內(nèi)置函數(shù)Math.max()和Math.min()方法

對(duì)于純數(shù)字?jǐn)?shù)組,可以使用JavaScript中的內(nèi)置函數(shù)Math.max()和Math.min()方法。使用這兩個(gè)內(nèi)置函數(shù)可以分別找出數(shù)組中的最大值和最上值。在使用這兩種內(nèi)置函數(shù)取出數(shù)組最大和最小值之前,先學(xué)習(xí)一下Math.max()和Math.min()兩個(gè)函數(shù)。

Math.max()

Math.max()函數(shù)返回一組數(shù)中的最大值。

Math.max(1,32,45,31,3442,4); // 3442

Math.max(10, 20); // 20

Math.max(-10, -20); // -10

Math.max(-10, 20); // 20

Math.min()

Math.min()函數(shù)和Math.max()函數(shù)剛好相反,其會(huì)返回一組數(shù)中的最小值:

Math.min(10,20); //10

Math.min(-10,-20); //-20

Math.min(-10,20); //-10

Math.min(1,32,45,31,3442,4); //1

這些函數(shù)如果沒(méi)有參數(shù),則結(jié)果為 -Infinity;如果有任一參數(shù)不能被轉(zhuǎn)換為數(shù)值,則結(jié)果為 NaN。最主要的是這兩個(gè)函數(shù)對(duì)于數(shù)字組成的數(shù)組是不能直接使用的。但是,這有一些類(lèi)似地方法。

Function.prototype.apply()讓你可以使用提供的this與參數(shù)組與的數(shù)組來(lái)調(diào)用參數(shù)。

// 取出數(shù)組中最大值

Array.max = function( array ){

return Math.max.apply( Math, array );

};

// 取出數(shù)組中最小值

Array.min = function( array ){

return Math.min.apply( Math, array );

};

var arr = [1,45,23,3,6,2,7,234,56];

Array.max(arr); // 234

Array.min(arr); // 1

Math對(duì)象也是一個(gè)對(duì)象,可以使用對(duì)象的字面量來(lái)寫(xiě),如:

Array.prototype.max = function () {

return Math.max.apply({},this);

}

Array.prototype.min = function () {

return Math.min.apply({},this);

}

var arr = [1,45,23,3,6,2,7,234,56];

arr.max(); // 234

arr.min(); // 1

其實(shí)還有更簡(jiǎn)單的方法?;贓S2015的方法來(lái)實(shí)現(xiàn)此功能,是使用展開(kāi)運(yùn)算符:

var numbers = [1, 2, 3, 4];

Math.max(...numbers) // 4

Math.min(...numbers) // 1

此運(yùn)算符使數(shù)組中的值在函數(shù)調(diào)用的位置展開(kāi)。

總結(jié)

這篇文章整理了幾個(gè)從數(shù)組中取出最大值和最小值的方法。這幾個(gè)方法都只是會(huì)對(duì)于數(shù)字?jǐn)?shù)組,而對(duì)于數(shù)組中包含其他數(shù)據(jù)類(lèi)型時(shí),如何只取出最大的數(shù)值和最小的數(shù)值(如果您知道如何實(shí)現(xiàn),還望指點(diǎn)迷津)。而這幾種方法當(dāng)中,使用JavaScript的內(nèi)置函數(shù)Math.max()和Math.min()配合Function.prototype.apply()可以輕松取出數(shù)組中的最大值和最小值。當(dāng)然最最簡(jiǎn)單的要當(dāng)數(shù)ES2015中使用展示運(yùn)算符的方法。

關(guān)于JavaScript學(xué)習(xí)筆記之取數(shù)組中最大值和最小值的方法就給大家介紹這么多,如果大家還有更好的方案,希望能在下面的評(píng)論中與我們一起分享。

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)