陣列去重
原理:定義一個物件obj,然後把陣列元素當作obj的屬性名,利用屬性名是否重複判重
var unique = function(arr){ let obj = {}; let newArr = []; arr.forEach(function(x){ if(!obj[x]){ //如果对象中没有该元素对应的属性 obj[x] = true; newArr.push(x); } }); return newArr; }
使用快速排序演算法對陣列進行排序
#這裡麵包含兩種效果,一種是利用快排的特性實現了去重快排,另一種是不去重的快排。
原理:取得目標數組,選定一個元素最為標誌位,遍歷剩餘的元素,比標誌位大放異彩右邊,比標誌位小放左邊。
特別注意:還有與標誌位相等的元素,如果你儲存相等的元素,就實現了去重,如果儲存了,就不去重。
var quickSort = function(arr){ if(arr.length <= 1){ return arr; } //定义一个左数组,定义一个右数组 let leftArr = []; let rightArr = []; //选定一个参照值 let tag = arr[0]; /* * 使用如下方式判断,会把重复元素去掉,就实现了快排的同时去重 */ for(let i = 0; i < arr.length; i++){ if(arr[i] < tag){ //将比tag小的元素放在左数组中 leftArr.push(arr[i]); } if(arr[i] > tag){ //将比tag大的元素放在右数组中 rightArr.push(arr[i]); } } /* * 使用如下方式就是使用快排进行排序,不去重 */ for(let i = 1; i < arr.length; i++){ if(arr[i] < tag){ //将比tag小的元素放在左数组中 leftArr.push(arr[i]); }else{ //将比tag大的元素放在右数组中 rightArr.push(arr[i]); } } //递归调用 return [].concat(quickSort(leftArr),[tag],quickSort(rightArr)); }
以上是javascript數組去重和快速排序演算法實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!