分享JS數(shù)組求和與求最大值的方法
前言
面試遇到一個(gè)問題:JS數(shù)組求和函數(shù)。我第一想到的就是數(shù)組循環(huán)。然而我覺得面試官問這個(gè)問題一定不是想考這個(gè)人人皆知的方法。當(dāng)時(shí)機(jī)智的我竟然想到了遞歸函數(shù)不斷加和數(shù)組的項(xiàng),然而折騰了好久都沒調(diào)好方法,事實(shí)證明這并不是最優(yōu)解。最后面試官問我有沒有見過reduce()
,真木有哇。所以回來查資料,Array.reduce()
是ES5新增的新屬性,相似的還有Array.reduceRight()。
下文來總結(jié)一下數(shù)組求和的方法。
最粗暴的方法:循環(huán)獲取
通過for循環(huán)一項(xiàng)項(xiàng)地加和。看代碼:
Array.prototype.sum = function (){ var result = 0; for(var i = 0; i < this.length; i++) { result += this[i]; } return result; }; [1,4,7,2,10].sum(); // 24
使用reduce方法
利用reduce
方法,可以寫一個(gè)數(shù)組求和的sum
方法。
reduce()
方法接收一個(gè)函數(shù)作為累加器,數(shù)組中的每個(gè)值(從左到右)開始縮減,最終為一個(gè)值。
reduce的語法:
array.reduce(callback[, initialValue]);
callback
函數(shù)接受4個(gè)參數(shù):previousValue
(上次調(diào)用回調(diào)返回的值)、currentValue
(當(dāng)前被處理的元素)、index
(索引)以及數(shù)組本身(第一次調(diào)用 callback
的第一個(gè)參數(shù)),執(zhí)行數(shù)組中每個(gè)值的函數(shù)。
initialValue
參數(shù)可選,表示初始值;initialValue
參數(shù)若指定,則當(dāng)作最初使用的previous
值,如果缺省,則使用數(shù)組的第一個(gè)元素作為previous
初始值,同時(shí)current
往后排一位。
Array.prototype.sum = function (){ return this.reduce(function (partial, value){ return partial + value; }) }; [1,4,7,2,10].sum(); // 24
相比第一種方法,使用reduce()
方法的效率更高。
這兩種方法的效率比較可以直接在函數(shù)運(yùn)行前后分別調(diào)用new Date()
獲取即時(shí)時(shí)間,從而通過時(shí)間差比較執(zhí)行時(shí)間。這里就不比較了,因?yàn)槊總€(gè)人的執(zhí)行環(huán)境差異較大。測(cè)試結(jié)果是reduce()
方法的執(zhí)行時(shí)間更短。
JS數(shù)組求和函數(shù),并求出數(shù)組中的最大值
實(shí)例代碼
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>腳本之家_js數(shù)組求和和最大值方法_腳本之家網(wǎng)</title> <meta name="keywords" content="站長(zhǎng),網(wǎng)頁特效,網(wǎng)頁特效代碼,js特效,js腳本,腳本,廣告代碼,jb51.net,www.dbjr.com.cn,腳本之家網(wǎng)" /> <meta name="description" content="www.dbjr.com.cn,腳本之家網(wǎng),站長(zhǎng)必備js特效及廣告代碼。大量高質(zhì)量js特效,提供高質(zhì)量廣告代碼下載,盡在腳本之家網(wǎng)" /> </head> <body> <a href="http://www.dbjr.com.cn/">腳本之家網(wǎng)</a>,站長(zhǎng)必備的高質(zhì)量網(wǎng)頁特效和廣告代碼。jb51.net,站長(zhǎng)js特效。<hr> <script type="text/javascript"> //求和 Array.prototype.sum = function () { for (var sum = i = 0; i < this.length; i++)sum += parseInt(this[i]); return sum ; }; //求最大值 Array.prototype.maxima = function () { for (var i = 0, maxValue = Number.MIN_VALUE; i < this.length; i++)parseInt(this[i]) > maxValue && (maxValue = this[i]); return maxValue; }; //應(yīng)用 var arr = [1,21,3,4,22,45,60,7,32]; alert(arr.join("+") + "=" + arr.sum()); alert(arr.join("|") + "中, 最大的數(shù)是:" + arr.maxima()); </script> </body> </html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家使用JavaScript有所幫助哦,如果有疑問的話歡迎留言討論,小編會(huì)及時(shí)回復(fù)大家的。
- Javascript獲取數(shù)組中的最大值和最小值的方法匯總
- JS獲取數(shù)組最大值、最小值及長(zhǎng)度的方法
- 求js數(shù)組的最大值和最小值的四種方法
- javascript實(shí)現(xiàn)查找數(shù)組中最大值方法匯總
- JS實(shí)現(xiàn)獲取數(shù)組中最大值或最小值功能示例
- JS中取二維數(shù)組中最大值的方法匯總
- JavaScript遍歷查找數(shù)組中最大值與最小值的方法示例
- JavaScript如何獲取數(shù)組最大值和最小值
- javascript實(shí)現(xiàn)數(shù)組最大值和最小值的6種方法
- js求數(shù)組最大值的八種具體實(shí)現(xiàn)方法
相關(guān)文章
原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法詳解
這篇文章主要介紹了原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript制作拼圖游戲的相關(guān)步驟、原理、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2020-02-02AJAX XMLHttpRequest對(duì)象創(chuàng)建使用詳解
這篇文章主要介紹了AJAX XMLHttpRequest對(duì)象創(chuàng)建使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08JS簡(jiǎn)單去除數(shù)組中重復(fù)項(xiàng)的方法
這篇文章主要介紹了JS簡(jiǎn)單去除數(shù)組中重復(fù)項(xiàng)的方法,涉及javascript針對(duì)數(shù)組的遍歷、判斷與運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2016-09-09JavaScript操作XML實(shí)例代碼(獲取新聞標(biāo)題并分頁,并分頁)
XML 代碼部分 這是一個(gè)新聞的XML 文件,如果 NBody部分包含 XML 和Html 不可識(shí)別部分, 就 包含在DATA 表示附中。2010-05-05微信小程序?qū)W習(xí)(4)-系統(tǒng)配置app.json詳解
我們使用app.json文件來對(duì)微信小程序進(jìn)行全局配置,決定頁面文件的路徑、窗口表現(xiàn)、設(shè)置網(wǎng)絡(luò)超時(shí)時(shí)間、設(shè)置多 tab 等。2017-01-01