摘要:插入排序在實現(xiàn)上,通常采用排序即只需用到的額外空間,因而在從后向前掃描過程中,需要反復(fù)把已排序元素逐步向后挪位,為最新元素提供插入空間。兩個相同的保持他們原來的前后順序,所以直接插入排序是穩(wěn)定的。
概述
插入排序是一種簡單直觀的排序算法。它的工作原理是通過構(gòu)建有序序列,對于未排序數(shù)據(jù),在已排序序列中從后向前掃描,找到相應(yīng)位置并插入。插入排序在實現(xiàn)上,通常采用 in-place 排序(即只需用到O(1)的額外空間),因而在從后向前掃描過程中,需要反復(fù)把已排序元素逐步向后挪位,為最新元素提供插入空間。
換句話說,就是:
假設(shè)在序號 i 之前的元素即 [0... i-1] 都已經(jīng)排好序,本趟需要找到 i 對應(yīng)的元素 x 的正確位置 k ,在尋找這個位置 k 的過程中逐個將比較過的元素往后移一位,為元素 x “騰位置”,最后將 k 位置對應(yīng)的元素值賦為 x ,插入排序的時間復(fù)雜度和空間復(fù)雜度分別為 O(n2) 和 O(1)。
步驟從第一個元素開始,該元素可以認(rèn)為已經(jīng)被排序
取出下一個元素,在已經(jīng)排序的元素序列中從后向前掃描
如果該元素(已排序)大于新元素,將該元素移到下一位置
重復(fù)步驟3,直到找到已排序的元素小于或者等于新元素的位置
將新元素插入到該位置中
重復(fù)步驟2,直到排好序為止
實例舉個簡單的例子,幫助理解。
原始數(shù)據(jù):
3 5 2 6 2
第一輪,把 3 作為已經(jīng)排好序的,取出 5 與 3 進(jìn)行比較,5 大于 3 位置保持不變,新的有序組為 [3 5]
3 5 2 6 2
第二輪,取出第一個 2 ,從已排序的 [3 5] 數(shù)組從后往前比較,與 5 比較,小于 5,將 5 向后移動一個位置,再與 3 比較,小于 3,將 3 向后移動一個位置,前面沒有了,將 2 放置在原來 3 的位置,新的有序組為 [2 3 5]
2 3 5 6 2
第三輪,取出 6 ,與 5 比較,5 保持不動,新的有序組 [2 3 5 6]
2 3 5 6 2
第四輪,取出 2 ,與 6 比較,6 向后移動一位,與 5 比較,5 向后移動一位,與 3 比較,3 向后移動一位,與 2 比較,不需移動,將取出的 2 放到原來 3 的位置即可,至此完成排序。
2 2 3 5 6
兩個相同的 2 保持他們原來的前后順序,所以直接插入排序是穩(wěn)定的。
代碼實現(xiàn)(Java)package com.coder4j.main.arithmetic.sorting; public class StraightInsertion { /** * 直接插入排序 * * @param array * @return */ public static int[] sort(int[] array) { // 將第一個i=0作為已排序組 for (int i = 1; i < array.length; i++) { System.out.println("第" + i + "輪比較結(jié)果:"); // 取出i索引待排序元素 int temp = array[i]; int j; // 從已排序數(shù)組后面往前逐個比較,確定i元素的位置,并將相應(yīng)的元素后移一位 for (j = i - 1; j >= 0 && temp < array[j]; j--) { array[j + 1] = array[j]; } // 找到了位置 array[j + 1] = temp; // 輸出此輪排序結(jié)果 for (int k : array) { System.out.print(k + " "); } System.out.println(); } return array; } public static void main(String[] args) { int[] array = { 3, 5, 2, 6, 2 }; int[] sorted = sort(array); System.out.println("最終結(jié)果"); for (int i : sorted) { System.out.print(i + " "); } } }
測試輸出結(jié)果:
第1輪比較結(jié)果: 3 5 2 6 2 第2輪比較結(jié)果: 2 3 5 6 2 第3輪比較結(jié)果: 2 3 5 6 2 第4輪比較結(jié)果: 2 2 3 5 6 最終結(jié)果 2 2 3 5 6
經(jīng)測試,與實例中結(jié)果一致。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/65417.html
希爾排序 在介紹希爾排序之前,先了解一下直接插入排序 文章目錄 希爾排序一、直接插入排序1. 單趟排序2. 直接插入排序 二、希爾排序三、測試希爾排序和直接插入排序性能 一、直接插入排序 1. 單趟排序 x插入一個有序區(qū)間 這里end是指向數(shù)組最后一個元素 2. 直接插入排序 根據(jù)上面的單趟排序啟發(fā) end是數(shù)組的最后一個元素,end之后的元素都是待排序 一個關(guān)鍵的判斷點,end和...
本篇有7k+字, 系統(tǒng)梳理了js中常見的12種排序算法。除了基本排序算法,文章還包含了希爾排序、堆排序、桶排序等較為復(fù)雜的排序?qū)崿F(xiàn),如果喜歡請點贊支持~謝謝. 原文: http://louiszhai.github.io/20... 導(dǎo)讀 排序算法可以稱得上是我的盲點, 曾幾何時當(dāng)我知道Chrome的Array.prototype.sort使用了快速排序時, 我的內(nèi)心是奔潰的(啥是快排, 我只知道...
摘要:一前言直接插入排序序是一種最簡單的插入排序。所以,數(shù)據(jù)越接近正序,直接插入排序的算法性能越好。算法穩(wěn)定性直接插入排序的過程中,不需要改變相等數(shù)值元素的位置,所以它是穩(wěn)定的算法。 一、前言直接插入排序(Insertion Sort)序是一種最簡單的插入排序。為簡化問題,我們下面只討論升序排序。 二、算法思想插入排序:每一趟將一個待排序的記錄,按照其關(guān)鍵字的大小插入到有序隊列的合適位置里,...
摘要:本篇博客我要來和大家一起聊一聊數(shù)據(jù)結(jié)構(gòu)初階中的最后一篇博客八大經(jīng)典排序算法的總結(jié),其中會介紹他們的原來,還有復(fù)雜度的分析以及各種優(yōu)化??焖倥判蜻f歸版本快速排序是于年提出的一種二叉樹結(jié)構(gòu)的交換排序方法。 ...
摘要:當(dāng)序列本身有序時,插入排序的時間復(fù)雜度為。因為此時的分區(qū)內(nèi)數(shù)據(jù)往往是近似有序的,所以使用快排并不一定優(yōu)于插入排序。 聲明:碼字不易,轉(zhuǎn)載請注明出處,歡迎文章下方討論交流。 前言:Java數(shù)據(jù)結(jié)構(gòu)與算法專題會不定時更新,歡迎各位讀者監(jiān)督。本篇文章介紹排序算法中插入排序算法,包括插入排序的思路,適用場景,性能分析,java代碼等 0、其他排序算法索引(待更) java數(shù)據(jù)結(jié)構(gòu)與算法——快速...
閱讀 3532·2021-09-27 13:35
閱讀 3571·2019-08-29 17:09
閱讀 2450·2019-08-26 11:30
閱讀 711·2019-08-26 10:32
閱讀 545·2019-08-26 10:23
閱讀 1206·2019-08-26 10:20
閱讀 3161·2019-08-23 15:26
閱讀 3571·2019-08-23 14:33