亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

八大排序算法詳解——插入排序

2019-11-10 17:05:10
字體:
來源:轉載
供稿:網友

基本思想

假設待排序的記錄存放在數組R[0..n-1]中。初始時,R[0]自成1個有序區,無序區為R[1..n-1]。 從i=1起直至i=n-1為止,依次將R[i]插入當前的有序區R[0..i-1]中,生成含n個記錄的有序區。

算法實現

直接插入排序算法,java實現,代碼如下所示:

public abstract class Sorter { public abstract void sort(int[] array);}public class StraightInsertionSorter extends Sorter { @Override public void sort(int[] array) { int tmp; for (int i = 1; i < array.length; i++) { tmp = array[i]; // array[i]的拷貝 // 如果右側無序區第一個元素array[i] < 左側有序區最大的array[i-1], // 需要將有序區比array[i]大的元素向后移動。 if (array[i] < array[i - 1]) { int j = i - 1; // 從右到左掃描有序區 while (j >= 0 && tmp < array[j]) { // 將左側有序區中元素比array[i]大的array[j+1]后移 array[j + 1] = array[j]; j--; } // 如果array[i]>=左側有序區最大的array[i-1],或者經過掃描移動后,找到一個比array[i]小的元素 // 將右側無序區第一個元素tmp = array[i]放到正確的位置上 array[j + 1] = tmp; } } }}

排序過程

直接插入排序的執行過程,如下所示:

初始化無序區和有序區:數組第一個元素為有序區,其余的元素作為無序區。遍歷無序區,將無序區的每一個元素插入到有序區正確的位置上。具體執行過程為:每次取出無序區的第一個元素,如果該元素tmp大于有序區最后一個元素,不做任何操作;如果tmp小于有序區最后一個元素,說明需要插入到有序區最后一個元素前面的某個位置,從后往前掃描有序區,如果有序區元素大于tmp,將有序區元素后移(第一次后移:tmp小于有序區最大的元素,有序區最大的元素后移覆蓋無序區第一個元素,而無序區第一個元素的已經拷貝到tmp中;第二次后移:tmp小于有序區從后向前第二個的元素,有序區從后向前第二個元素后移覆蓋有序區最大元素的位置,而有序區最后一個元素已經拷貝到無序區第一個元素的位置上;以此類推),直到找到一個元素比tmp小的元素(如果沒有找到,就插入到有序區首位置),有序區后移操作停止。接著,將tmp插入到:從有序區由前至后找到的第一個比tmp小的元素的后面即可。此時,有序區增加一個元素,無序區減少一個元素,直到無序區元素個數為0,排序結束。

下面,通過實例來演示執行直接插入排序的過程,假設待排序數組為array = {94,12,34,76,26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49},數組大小為20,則執行排序過程如下所示:

初始有序區為{94},無序區為{12,34,76,26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49}。對于array[1] = 12(無序區第一個元素):臨時拷貝tmp = array[1] = 12,tmp = 12小于有序區{94}最后一個元素(94),因為有序區只有一個元素,所以將tmp插入到有序區首位置,此時,有序區為{12,94},無序區為{34,76,26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49}。對于array[2] = 34(無序區第一個元素):臨時拷貝tmp = array[2] = 34,tmp = 34小于有序區{12,94}最后一個元素(94),將94后移覆蓋array[2],亦即:array[2] = 94;繼續將tmp = 34與有序區{12,94}從后向前第二個元素比較,tmp = 34 > 12,則直接將tmp = 34插入到12后面的位置。此時,有序區為{12,34,94},無序區為{76,26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49}。對于array[3] = 76(無序區第一個元素):臨時拷貝tmp = array[3] = 76,tmp = 76小于有序區{12,34,94}最后一個元素(94),將94后移覆蓋array[3],亦即:array[3] = 94;繼續將tmp = 76與有序區{12,34,94}從后向前第二個元素比較,tmp = 76 > 34,則直接將tmp = 76插入到34后面的位置。此時,有序區為{12,34,76,94},無序區為{26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49}。

……依此類推執行,直到無序區沒有元素為止,則有序區即為排序后的數組。

算法分析

時間復雜度最好情況:有序

通過直接插入排序的執行過程可以看到,如果待排序數組恰好為有序,則每次從大小為n-1的無序區數組取出一個元素,和有序區最后一個元素比較,一定是比最后一個元素大,需要插入到有序區最后一個元素的后面,也就是原地插入??梢姡容^次數為n-1次,數組元素移動次數為0次。

最壞情況:逆序

每次從無序區取出第一個元素,首先需要與有序區最后一個元素比較一次,然后繼續從有序區的最后一個元素比較,直到比較到有序區第一個元素,然后插入到有序區首位置。每次從無序區取出第一個元素,移動放到拷貝tmp中,然后再將tmp與有序區元素比較,這個比較過程一共移動的次數為:有序區數組大小,最后還要將拷貝tmp移動插入到有序區的位置上。在這個過程中:有序區數組大小為1時,比較2次,移動3次;有序區數組大小為2時,比較3次,移動4次;……有序區數組大小為n-1時,比較n次,移動n+1次??梢姡罕容^的次數為:2+3+……+n = (n+2)(n-1)/2移動的此時為:3+4+……+n+1 = (n+4)(n-1)/2

通過上面兩種情況的分析,直接插入排序的時間復雜度為O(n2)。

空間復雜度

在直接插入排序的過程中,只用到一個tmp臨時存放待插入元素,因此空間復雜度為O(1)。

排序穩定性

通過上面的例子來看:當有序區為{0,9,12,26,34,37,55,76,94},無序區為{76,37,5,68,83,90,37,12,65,76,49}的時候,執行下一趟直接插入排序:對于array[9] = 76(無序區第一個元素):臨時拷貝tmp = array[9] = 76,tmp = 76小于有序區{0,9,12,26,34,37,55,76,94}最后一個元素(94),將94后移覆蓋array[9],亦即:array[9] = 94;繼續將tmp = 76與有序區{0,9,12,26,34,37,55,76,94}從后向前第二個元素(76)比較,tmp = 76 = 76,則直接將tmp = 76插入到有序區數組元素76后面的位置。此時,有序區為{0,9,12,26,34,37,55,76,76,94},無序區為{37,5,68,83,90,37,12,65,76,49}。繼續執行直至完成的過程中,對于兩個相等的數組元素,原始為排序數組中索引位置的大小關系并沒有發生改變,也就是說,對于值相等的元素e,存在ei1,ei2,……eik,其中i1,i2……ik是數組元素e在為排序數組中的索引位置,排序前有i1<i2<……<ik,排序后仍然有j1<j2<……<jk,其中j1<j2<……<jk為排序后值相等的元素e的索引。

可見,直接插入排序是穩定的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人黄色免费看| 久热99视频在线观看| 国产一区视频在线| 国产91露脸中文字幕在线| 欧美精品免费在线观看| 欧美黄网免费在线观看| 国产精品狠色婷| 欧美巨猛xxxx猛交黑人97人| 亲子乱一区二区三区电影| 精品丝袜一区二区三区| 黑人与娇小精品av专区| 亚洲国产天堂网精品网站| 中文字幕亚洲一区| 亚洲香蕉在线观看| 91精品国产91久久久久久久久| 亚洲美女av网站| 成人久久久久爱| 国产精品免费观看在线| 97成人精品视频在线观看| 国产做受69高潮| 欧美夜福利tv在线| 日本成人黄色片| 久久久久免费精品国产| 亚洲精品国精品久久99热| 免费av在线一区| 久久综合88中文色鬼| 91性高湖久久久久久久久_久久99| 97在线视频国产| 亚洲福利视频网| 亚洲黄色av网站| 精品国产依人香蕉在线精品| 久久久久久久一区二区| 日韩天堂在线视频| 欧美激情精品久久久久| 久精品免费视频| 精品国产精品三级精品av网址| 日本伊人精品一区二区三区介绍| 国产成人亚洲综合| 国产成人福利视频| 亚洲国产日韩一区| 亚洲人成电影网站色www| 青青久久av北条麻妃黑人| 日韩中文字幕国产| 日韩经典中文字幕在线观看| 国产成人精品久久亚洲高清不卡| 人人做人人澡人人爽欧美| 国产成人综合一区二区三区| 久久久久日韩精品久久久男男| 亚洲色图17p| 国精产品一区一区三区有限在线| 国产精品久久久久久久久久| 久久精品国产综合| 亚洲人成自拍网站| 欧美在线欧美在线| 欧美日韩美女在线| 欧美精品激情在线观看| 久久综合亚洲社区| 亚洲xxxx做受欧美| 亚洲欧美一区二区激情| 成人国内精品久久久久一区| 国产人妖伪娘一区91| 久久中文字幕国产| 欧美国产视频一区二区| 欧美成人自拍视频| 色播久久人人爽人人爽人人片视av| 国产精品 欧美在线| 久久久在线免费观看| 91手机视频在线观看| 亚洲国产中文字幕久久网| 91热福利电影| 黄色成人在线免费| 欧美理论电影在线观看| 日韩在线观看免费网站| 日韩欧美中文字幕在线观看| 91成人免费观看网站| 国产成人欧美在线观看| 亚洲男人天堂2019| 精品国产一区二区三区久久狼黑人| 欧美激情一区二区三区高清视频| 欧美成人精品在线播放| 色无极影院亚洲| 在线精品国产成人综合| xxxx欧美18另类的高清| 中文.日本.精品| 亚洲天堂成人在线| 日日狠狠久久偷偷四色综合免费| 亚洲国产又黄又爽女人高潮的| 色婷婷成人综合| 美女扒开尿口让男人操亚洲视频网站| 国产精品视频白浆免费视频| 久久电影一区二区| 国产成人免费av电影| 伊人一区二区三区久久精品| 亚洲国产精品久久久| 91精品国产自产在线| 中文字幕日韩av电影| 亚洲视频在线观看免费| 亚洲图片制服诱惑| 精品偷拍一区二区三区在线看| 日韩欧美在线一区| 国产精品福利在线观看| 久久久精品日本| 久久精视频免费在线久久完整在线看| 亚洲成avwww人| 2019亚洲男人天堂| 欧美成人免费一级人片100| 97超级碰碰人国产在线观看| 亚洲国产高清自拍| 欧美日韩成人在线观看| 中文字幕免费精品一区高清| 色综合伊人色综合网| 日韩av在线免费看| 亚洲网站视频福利| 国产极品精品在线观看| 亚洲视频在线观看免费| 一区国产精品视频| 国产亚洲精品激情久久| 久久精品中文字幕免费mv| 国产精品日韩电影| 91国产精品视频在线| 日本免费一区二区三区视频观看| 亚洲欧美激情视频| 欧美日韩福利视频| 久久久伊人欧美| 亚洲天堂av在线播放| 日韩精品小视频| 国产中文日韩欧美| 久久久亚洲成人| 精品福利在线观看| 国产精品一久久香蕉国产线看观看| 欧美丰满少妇xxxxx| 北条麻妃一区二区三区中文字幕| 久久久噜噜噜久噜久久| 成人av资源在线播放| 国产裸体写真av一区二区| 成人免费观看49www在线观看| 亚洲一区精品电影| 欧美性感美女h网站在线观看免费| 欧美激情三级免费| 中文字幕综合在线| 中国人与牲禽动交精品| 欧美激情欧美激情| 日韩欧美中文在线| 91久久精品在线| 亚洲跨种族黑人xxx| 亚洲最大福利视频网| 91久久精品国产| 日韩欧美精品免费在线| 久久久国产精品视频| 日韩激情av在线播放| 欧美精品日韩三级| 成人午夜一级二级三级| 综合国产在线观看| 国产精品女人久久久久久| 亚洲国内精品视频| 亚洲一区二区三区在线免费观看| 7777精品久久久久久| 亚洲自拍小视频| 一区二区三欧美| 日韩免费高清在线观看| 欧美巨乳在线观看| 岛国av午夜精品| 久久影视电视剧免费网站清宫辞电视| 午夜精品久久久久久久白皮肤|