排序算法-插入排序

一、原理解析

  1. 從第一個(gè)元素開(kāi)始,該元素可以認(rèn)為已經(jīng)被排序
  2. 取出下一個(gè)元素,在已經(jīng)排序的元素序列中從后向前掃描
  3. 把取出的元素放到已排序的元素中間的合適位置
  4. 重復(fù)步驟2~3

就像排隊(duì)一樣,依次每次挑一個(gè)同學(xué),把該同學(xué)“插入”到已經(jīng)排好的部分隊(duì)伍里。

二、范例演示

以下表格里,紅色表示選中的待排序的數(shù)字,藍(lán)色表示最終排好的數(shù)字。

第一輪:對(duì)于第一個(gè)元素(紅色),變成已排序元素(藍(lán)色)

第二輪:對(duì)于第二個(gè)元素,和已排序元素(藍(lán)色數(shù)字)比較,插入到已排序元素中合適的位置(8放到10前面,之后都變成已排序元素)

第三輪:對(duì)于第三個(gè)元素,和已排序元素(藍(lán)色數(shù)字)比較,插入到已排序元素中合適的位置(9放到8和10中間,之后變成已排序元素)

...

三、實(shí)現(xiàn)方式

插入法JS 版

function insertionSort(arr) {
  for(let i = 1; i < arr.length; i++) {
    for(let j = 0; j < i; j++) {
      if(arr[i] < arr[j]) {
        arr.splice(j, 0, arr[i])
        arr.splice(i+1, 1)
        break
      }
      console.log(arr)
    }
  }
}

var arr = [10, 34, 21, 47, 3, 28]
insertionSort(arr)
console.log(arr)

插入法普通版

function insertionSort(arr) {
  for(var i = 1; i < arr.length; i++) {
    var temp = arr[i]
    for(var j = i; j > 0 && arr[j-1] > temp; j--) {
      arr[j] = arr[j-1]
    }
    arr[j] = temp
  }
}

var arr = [10, 34, 21, 47, 3, 28]
insertionSort(arr)
console.log(arr)

復(fù)雜度分析

時(shí)間復(fù)雜度為 O(n^2)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 冒泡排序插入排序插入排序和冒泡排序分析 冒泡排序 冒泡排序(英語(yǔ):Bubble Sort,臺(tái)灣另外一種譯名為:泡沫...
    六尺帳篷閱讀 2,333評(píng)論 0 9
  • 插入排序?qū)τ谏倭吭氐呐判蚴呛芨咝У?,而且這個(gè)排序的手法在每個(gè)人生活中也是有的哦。你可能沒(méi)有意識(shí)到,當(dāng)你打牌的時(shí)候...
    周小春閱讀 481評(píng)論 0 0
  • 一、插入排序 插入排序(Insertion sort)是一種簡(jiǎn)單直觀(guān)且穩(wěn)定的排序算法。 算法思維 每次將一個(gè)待排序...
    Alcazar閱讀 1,659評(píng)論 0 2
  • 插入排序(Insertion sort)是一種簡(jiǎn)單直觀(guān)且穩(wěn)定的排序算法。如果有一個(gè)已經(jīng)有序的數(shù)據(jù)序列,要求在這個(gè)已...
    夏天的夏秋天的天閱讀 371評(píng)論 0 0
  • 我的電商生涯持續(xù)了23個(gè)月,只差一個(gè)月就滿(mǎn)兩年,而我,果斷結(jié)束了。 2016年10月份我的大兒子出生,我老公經(jīng)營(yíng)著...
    夏吟晨閱讀 3,034評(píng)論 40 92

友情鏈接更多精彩內(nèi)容