【算法】插入排序算法的講解和代碼實(shí)踐

思路

有數(shù)組[26, -3, 14, -15, 0, 324, 98, 1, 22]
現(xiàn)對(duì)該數(shù)組進(jìn)行排序狠毯,使用插入排序算法蚕脏。
先來(lái)屢一下思路和步驟:

  1. 從下標(biāo)為1的元素開(kāi)始進(jìn)行遍歷;
  2. 如果它前面的元素比它大,那么將前面的元素進(jìn)行后移回挽,并記錄下標(biāo);
  3. 直至遇見(jiàn)小于等于它的數(shù)猩谊,將當(dāng)前元素插入上面記錄的下標(biāo)中千劈。

講解

第一步,記錄當(dāng)前元素(從下標(biāo)為1的元素開(kāi)始)牌捷,即 -3墙牌;插入下標(biāo)初始化為 -1。


image.png

第二步暗甥,將 -3 前面的所有元素與 -3 進(jìn)行對(duì)比喜滨,大于 -3 的,進(jìn)行后移撤防,并將后移元素的下標(biāo)賦值到插入下標(biāo)中:


image.png

第三步虽风,將當(dāng)前元素 -3 插入到插入下標(biāo)的位置:
image.png

這樣就完成了一個(gè)元素的插入排序。以此類推即可完成整個(gè)數(shù)組排序寄月。

實(shí)現(xiàn)

    @Test
    public void sortTest() {
        int[] nums = new int[]{26, -3, 14, -15, 0, 324, 98, 1, 22};
        insertSort(nums);
        System.out.println(Arrays.toString(nums));
    }

    private void insertSort(int[] nums) {
        if (nums.length < 2) {
            return;
        }
        // 從下標(biāo)為1的元素開(kāi)始遍歷
        for (int i = 1; i < nums.length; i++) {
            // 記錄當(dāng)前元素
            int cur = nums[i];
            // 初始化插入下標(biāo)為-1
            int insertIndex = -1;
            // 遍歷當(dāng)前元素前面的所有元素
            for (int j = i - 1; j >= 0; j--) {
                // 如果前面的某個(gè)元素大于當(dāng)前元素辜膝,則前面的元素后移一位
                if (nums[j] > cur) {
                    // 元素后移
                    nums[j + 1] = nums[j];
                    // 記錄插入下標(biāo)
                    insertIndex = j;
                }
            }
            // 如果插入下標(biāo)不等于-1,將當(dāng)前元素賦值到插入下標(biāo)
            if (insertIndex != -1) {
                nums[insertIndex] = cur;
            }
        }
    }

看一下運(yùn)行結(jié)果:


image.png

這樣插入排序就實(shí)現(xiàn)完成了漾肮。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末厂抖,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子克懊,更是在濱河造成了極大的恐慌忱辅,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谭溉,死亡現(xiàn)場(chǎng)離奇詭異墙懂,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)扮念,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)垒在,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人扔亥,你說(shuō)我怎么就攤上這事场躯。” “怎么了旅挤?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵踢关,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我粘茄,道長(zhǎng)签舞,這世上最難降的妖魔是什么秕脓? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮儒搭,結(jié)果婚禮上吠架,老公的妹妹穿的比我還像新娘。我一直安慰自己搂鲫,他們只是感情好傍药,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著魂仍,像睡著了一般拐辽。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上擦酌,一...
    開(kāi)封第一講書(shū)人閱讀 49,071評(píng)論 1 285
  • 那天俱诸,我揣著相機(jī)與錄音,去河邊找鬼赊舶。 笑死睁搭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的笼平。 我是一名探鬼主播介袜,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼出吹!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起辙喂,我...
    開(kāi)封第一講書(shū)人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤捶牢,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后巍耗,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體秋麸,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年炬太,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了灸蟆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡亲族,死狀恐怖炒考,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情霎迫,我是刑警寧澤斋枢,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站知给,受9級(jí)特大地震影響瓤帚,放射性物質(zhì)發(fā)生泄漏描姚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一戈次、第九天 我趴在偏房一處隱蔽的房頂上張望轩勘。 院中可真熱鬧,春花似錦怯邪、人聲如沸绊寻。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)榛斯。三九已至,卻和暖如春搂捧,著一層夾襖步出監(jiān)牢的瞬間驮俗,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工允跑, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留王凑,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓聋丝,卻偏偏與公主長(zhǎng)得像索烹,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子弱睦,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

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