首頁  >  文章  >  web前端  >  javascript數組去重和快速排序演算法實例詳解

javascript數組去重和快速排序演算法實例詳解

伊谢尔伦
伊谢尔伦原創
2017-07-24 09:23:211947瀏覽

陣列去重

原理:定義一個物件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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn