排序算法總結(jié)

選擇排序

遞歸寫法

思路:每次找到最小的數(shù)放在前面佛点,然后后面的數(shù)做一樣的事情

let min = (numbers) => {
if (numbers.length > 2) {
return min([numbers[0], min(numbers.slice(1))]);
} else {
return Math.min.apply(null, numbers);
}
}; //求數(shù)組最小值

let minIndex = (numbers) => numbers.indexOf(min(numbers)); //拿到最小值的下標(biāo)

let sort = (numbers) => {
if (numbers.length > 2) {
let index = minIndex(numbers); //最小值下標(biāo)
let min = numbers[index]; //找到最小值
numbers.splice(index, 1); //把當(dāng)前最小值從數(shù)組沖剔除
return [min].concat(sort(numbers)); //遞歸:繼續(xù)排序剩余數(shù)組
} else {
return numbers[0] < numbers[1] ? numbers : numbers.reverse();
}
};

循環(huán)寫法

思路大致相同:先把最小值放在前面醇滥,后面執(zhí)行i++

let minIndex = (numbers) => {
let index = 0;
for (let i = 1; i < numbers.length; i++) {
if (numbers[i] < numbers[index]) {
index = i; //遍歷過程中每遇到一個比當(dāng)前數(shù)小的數(shù)就認(rèn)為是最小值,直到遍歷結(jié)束
}
}
return index;
};

let swap = (array, i, j) => {
let temp = array[i]; //把i放入容器temp
array[i] = array[j]; //j給i
array[j] = temp; //容器中的內(nèi)容i給j超营,實現(xiàn)交換
};

let sort = (numbers) => {
for (let i = 0; i < numbers.length - 1; i++) {
let index = minIndex(numbers.slice(i)) + i;
if (index != i) {
swap(numbers, index, i);
}
}
return numbers;
};

快速排序

思路:以某個數(shù)為基準(zhǔn)鸳玩,比它小的數(shù)放前面,比它大的數(shù)放后面演闭,對每個數(shù)都做這樣的操作實現(xiàn)排序

//快速排序 遞歸思路
let quickSort = (arr) => {
  if (arr.length <= 1) {
    return arr;
  }
  let pivotIndex = Math.floor(arr.length / 2); //設(shè)定基準(zhǔn)數(shù)的下標(biāo)
  let pivot = arr.splice(pivotIndex, 1)[0]; //拿出基準(zhǔn)數(shù)不跟,因為會返回一個數(shù)組所以要標(biāo)注第零項
  let left = []; //比標(biāo)準(zhǔn)數(shù)字小的數(shù)組
  let right = []; //比標(biāo)準(zhǔn)數(shù)大的數(shù)組
  for (let i = 0; i < arr.length; i++) {
    if (arr[i] < pivot) {
      left.push(arr[i]);
    } else [right.push(arr[i])];
  }
  return quickSort(left).concat([pivot], quickSort(right)); //實現(xiàn)排序
};

歸并算法

思路:不找基準(zhǔn)數(shù),左邊一半排好序米碰,右邊一半排好序躬拢,最后左右兩邊進(jìn)行歸并。

let mergeSort = (arr) => {
  if (arr.length === 1) {
    return arr;
  }
  let left = arr.slice(0, Math.floor(arr.length / 2)); //左邊數(shù)組截取為0到數(shù)組的2分之1
  let right = arr.slice(Math.floor(arr.length / 2)); //右邊數(shù)組截取為從2分之1開始
  return merge(mergeSort(left), mergeSort(right)); //對左右兩部分繼續(xù)進(jìn)行mergeSort的操作后進(jìn)行歸并
};

let merge = (a, b) => {
  if (a.length === 0) return b;
  if (b.length === 0) return a; //特殊情況a或者b為空數(shù)組則直接返回另一半
  return a[0] > b[0]
    ? [b[0]].concat(merge(a, b.slice(1)))
    : [a[0]].concat(merge(a.slice(1), b)); //實現(xiàn)歸并排序
};

計數(shù)排序

思路:用一個哈希表做記錄见间,發(fā)現(xiàn)數(shù)字N就記N:1聊闯,如果再次發(fā)現(xiàn)N就加一
最后把哈希表的key都打出來

let countingSort = (arr) => {
  let hashTable = {};
  let result = [];
  let max = 0;
  for (let i = 0; i < arr.length; i++) {
    //遍歷數(shù)組
    if (!(arr[i] in hashTable)) {
      hashTable[arr[i]] = 1; //把數(shù)組內(nèi)容寫進(jìn)來
    } else {
      hashTable[arr[i]] += 1;
    }
    if (arr[i] > max) {
      max = arr[i]; //max會成為數(shù)組內(nèi)最大的
    }
  }

  for (let n = 0; n <= max; n++) {
    //遍歷哈希表
    if (n in hashTable) {
      for (let i = 0; i < hashTable[n]; i++) {
        //再次遍歷,拿到哈希的value,實現(xiàn)多次輸出
        result.push(n);
      }
    }
  }
  return result;
};


以上四種算法的時間復(fù)雜度

選擇排序 O(n^2)
快速排序 O(n log2 n)
歸并排序 O(n log2 n)
計數(shù)排序 O(n + max)


還有四種排序算法是:
冒泡排序
插入排序
希爾排序
基數(shù)排序

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末米诉,一起剝皮案震驚了整個濱河市菱蔬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌史侣,老刑警劉巖拴泌,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異惊橱,居然都是意外死亡蚪腐,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進(jìn)店門税朴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來回季,“玉大人,你說我怎么就攤上這事正林∨菀唬” “怎么了?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵觅廓,是天一觀的道長鼻忠。 經(jīng)常有香客問我,道長杈绸,這世上最難降的妖魔是什么帖蔓? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任矮瘟,我火速辦了婚禮,結(jié)果婚禮上塑娇,老公的妹妹穿的比我還像新娘芥永。我一直安慰自己,他們只是感情好钝吮,可當(dāng)我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布埋涧。 她就那樣靜靜地躺著,像睡著了一般奇瘦。 火紅的嫁衣襯著肌膚如雪棘催。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天耳标,我揣著相機與錄音醇坝,去河邊找鬼。 笑死次坡,一個胖子當(dāng)著我的面吹牛呼猪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播砸琅,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼宋距,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了症脂?” 一聲冷哼從身側(cè)響起谚赎,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎诱篷,沒想到半個月后壶唤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡棕所,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年闸盔,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片琳省。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡迎吵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出岛啸,到底是詐尸還是另有隱情钓觉,我是刑警寧澤茴肥,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布坚踩,位于F島的核電站,受9級特大地震影響瓤狐,放射性物質(zhì)發(fā)生泄漏瞬铸。R本人自食惡果不足惜批幌,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嗓节。 院中可真熱鬧荧缘,春花似錦、人聲如沸拦宣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鸵隧。三九已至绸罗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間豆瘫,已是汗流浹背珊蟀。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留外驱,地道東北人育灸。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像昵宇,于是被迫代替她去往敵國和親磅崭。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內(nèi)容