400-650-7353
您所在的位置:首頁(yè) > IT干貨資料 > web前端 > 【W(wǎng)eb前端基礎(chǔ)知識(shí)】數(shù)組去重的方法

【W(wǎng)eb前端基礎(chǔ)知識(shí)】數(shù)組去重的方法

  • 發(fā)布: 優(yōu)就業(yè)it培訓(xùn)
  • 來(lái)源:優(yōu)就業(yè)
  • 2021-06-18 17:12:08
  • 閱讀()
  • 分享
  • 手機(jī)端入口

無(wú)論是在面試還是實(shí)際寫(xiě)代碼中都會(huì)經(jīng)常遇到數(shù)組去重,那接下來(lái)我們介紹幾種數(shù)組去重的方法。

  1. var arr = [3,6,4,1,8,8,8,8,8,4,0,9,2,7,8,5,3,4,8,9,3]; 

1、第一種是聲明一個(gè)空數(shù)組,通過(guò)indexOf( )查找的方法,判斷這個(gè)新數(shù)組中有沒(méi)有該元素,如果沒(méi)有即查找結(jié)果為 -1 時(shí),將這個(gè)元素添加到新數(shù)組的末尾。

js代碼為:

  1. //1.創(chuàng)建一個(gè)空數(shù)組,把a(bǔ)rr里面的元素往空對(duì)象中添加,判斷如果空數(shù)組沒(méi)有這個(gè)元素,加 
  2.        var array = []; 
  3.        for( var i = 0; i<arr.length; i++ ) { 
  4.            if( array.indexOf(arr[i]) == -1 ) { 
  5.                array.push( arr[i] ); 
  6.            } 
  7.        } 
  8.         console.log(array); 

2、第二種是操作數(shù)組自身:

從第一項(xiàng)開(kāi)始,拿該項(xiàng)和后面的所有項(xiàng)作比較,如果后面有和比較項(xiàng)相等的,就把后面的一項(xiàng)刪除。刪除的方法會(huì)改變當(dāng)前數(shù)組的長(zhǎng)度,后面的元素會(huì)自動(dòng)往前挪,所以補(bǔ)位上來(lái)的元素需要在進(jìn)行一次比較,讓下標(biāo)進(jìn)行自減操作。

比較的詳細(xì)過(guò)程即是為:

拿數(shù)組中第一個(gè)元素,和后面所有的元素進(jìn)行比較,如果一樣刪除后面哪一個(gè)

拿數(shù)組中第二個(gè)元素,和后面所有的元素進(jìn)行比較,如果一樣刪除后面哪一個(gè)

...

數(shù)組中所有的元素后需要和后面的進(jìn)行比較,所以需要進(jìn)行for循環(huán)的嵌套

代碼為:

  1. for(var i = 0; i<arr.length; i++) { 
  2.             //和后面所有的元素進(jìn)行比較 
  3.             for(var j = i+1; j<arr.length; j++) { 
  4.                 if( arr[i] == arr[j] ){ //重復(fù),刪除后面的元素 
  5.                     arr.splice(j,1); 
  6.                     j--;  
  7. //刪除一個(gè)元素后元素位置會(huì)自動(dòng)往前挪,下標(biāo)也需要往前j-- 
  8.                 } 
  9.             } 
  10.         } 
  11.         console.log(arr); 

3、先使用sort()方法對(duì)數(shù)組進(jìn)行排序,再比較看數(shù)組是否和相鄰的項(xiàng)相等,如果不同則存入新數(shù)組中

  1. // 先對(duì)數(shù)組進(jìn)行sort排序 
  2.  var sortArr = arr.sort(); 
  3. // 初始化結(jié)果數(shù)組并存一個(gè)值 
  4.             var res = [sortArr[0]]; 
  5. // 循環(huán)遍歷數(shù)組進(jìn)行比較 
  6.             for (var i = 1; i < sortArr.length; i++) { 
  7. // 如果當(dāng)前的比較項(xiàng)與結(jié)果數(shù)組的最后一項(xiàng)不相等則放入 
  8.                 if (sortArr[i] !== res[res.length - 1]) { 
  9.                     res.push(sortArr[i]); 
  10.                 } 
  11.             } 
  12.             console.log(res); 

 

文章“【W(wǎng)eb前端基礎(chǔ)知識(shí)】數(shù)組去重的方法”已幫助

>>本文地址:http://liujunjsxg.cn/zhuanye/2021/69054.html

THE END  

聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。

1 您的年齡

2 您的學(xué)歷

3 您更想做哪個(gè)方向的工作?

獲取測(cè)試結(jié)果
  • 大前端大前端
  • 大數(shù)據(jù)大數(shù)據(jù)
  • 互聯(lián)網(wǎng)營(yíng)銷互聯(lián)網(wǎng)營(yíng)銷
  • JavaJava
  • Linux云計(jì)算Linux
  • Python+人工智能Python
  • 嵌入式物聯(lián)網(wǎng)嵌入式
  • 全域電商運(yùn)營(yíng)全域電商運(yùn)營(yíng)
  • 軟件測(cè)試軟件測(cè)試
  • 室內(nèi)設(shè)計(jì)室內(nèi)設(shè)計(jì)
  • 平面設(shè)計(jì)平面設(shè)計(jì)
  • 電商設(shè)計(jì)電商設(shè)計(jì)
  • 網(wǎng)頁(yè)設(shè)計(jì)網(wǎng)頁(yè)設(shè)計(jì)
  • 全鏈路UI/UE設(shè)計(jì)UI設(shè)計(jì)
  • VR/AR游戲開(kāi)發(fā)VR/AR
  • 網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全
  • 新媒體與短視頻運(yùn)營(yíng)新媒體
  • 直播帶貨直播帶貨
  • 智能機(jī)器人軟件開(kāi)發(fā)智能機(jī)器人
 

快速通道fast track

近期開(kāi)班時(shí)間TIME