排序算法-插入排序

插入排序的思想是吟逝,先看數(shù)組的第一個(gè)元素帽蝶,把它作為一個(gè)有序序列,再看第二個(gè)元素块攒,與第一個(gè)元素進(jìn)行比較與交換励稳,這樣子前兩個(gè)元素就成為了一個(gè)有序序列。繼續(xù)看第三個(gè)元素局蚀,與第二個(gè)麦锯、第一個(gè)元素進(jìn)行比較、交換琅绅,讓前三個(gè)元素形成一個(gè)有序序列。以此類推...
但是需要注意的是鹅巍,當(dāng)我們要把第n的元素插入時(shí)千扶,需要先與第n-1個(gè)元素比較,如果不小于說(shuō)明第n個(gè)元素的位置已經(jīng)找到了骆捧,為什么呢澎羞,因?yàn)榈趎個(gè)元素前面的元素已經(jīng)是一個(gè)有序序列了,第n個(gè)元素不大于前面的元素敛苇,那么它也不大于其他前面的元素妆绞,所以它所在的位置就是加入它然后成為一個(gè)有序序列的位置顺呕。

    // 插入排序
    public static void insertionSort(int[] arr) {
        // 從1開始循環(huán),第一個(gè)元素默認(rèn)有序
        for (int i = 1; i < arr.length; i++) {
            // 為下標(biāo)為i的元素找它的位置
            for (int j = i; j > 0; j--) {
                // 如果下標(biāo)為i的元素比它前面的元素小
                if (arr[j] < arr[j - 1]) {
                    // 與它前面的元素交換
                    // 這樣子下標(biāo)為i的元素就到了它的前一個(gè)元素的位置
                    int swaper = arr[j];
                    arr[j] = arr[j - 1];
                    arr[j - 1] = swaper;
                } else {
                    // 如果不滿足就說(shuō)明已經(jīng)找到了位置
                    // 因?yàn)樗懊娴脑亟M成的序列已經(jīng)是有序的了
                    break;
                }
            }
        }
    }

通過(guò)上面的代碼括饶,我們發(fā)現(xiàn)其中有可以優(yōu)化的地方
交換操作要執(zhí)行三個(gè)語(yǔ)句株茶,我們其實(shí)不需要這么多的交換操作,只需要把當(dāng)前要插入的數(shù)字保存起來(lái)图焰,然后看前面的數(shù)字是否大于這個(gè)數(shù)字启盛,如果大于直接覆蓋這個(gè)值就好了,具體看代碼技羔。

    // 插入排序的優(yōu)化版本
    public static void insertionSort(int[] arr) {
        // 從1開始循環(huán)僵闯,第一個(gè)元素默認(rèn)有序
        for (int i = 1; i < arr.length; i++) {
            // 保存需要插入元素的值
            int temp = arr[i];
            // j為要插入元素的位置
            int j;
            for (j = i; j > 0; j--) {
                // 如果下標(biāo)為i的元素比它前面的元素小
                if (temp < arr[j - 1]) {
                    arr[j] = arr[j - 1];
                } else {
                    // 如果不滿足就說(shuō)明已經(jīng)找到了位置
                    // 因?yàn)樗懊娴脑亟M成的序列已經(jīng)是有序的了
                    break;
                }
            }
            arr[j] = temp;    
        }
    }

這樣子我們循環(huán)里就只有簡(jiǎn)單的賦值操作了,提高了效率藤滥。

對(duì)比選擇排序鳖粟,不能有效的利用元素本來(lái)的部分有序這個(gè)性質(zhì),所以在基本有序的序列里拙绊,插入排序的效率十分高牺弹。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市时呀,隨后出現(xiàn)的幾起案子张漂,更是在濱河造成了極大的恐慌,老刑警劉巖谨娜,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件航攒,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡趴梢,警方通過(guò)查閱死者的電腦和手機(jī)漠畜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)坞靶,“玉大人憔狞,你說(shuō)我怎么就攤上這事≌靡酰” “怎么了瘾敢?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)尿这。 經(jīng)常有香客問(wèn)我簇抵,道長(zhǎng),這世上最難降的妖魔是什么射众? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任碟摆,我火速辦了婚禮,結(jié)果婚禮上叨橱,老公的妹妹穿的比我還像新娘典蜕。我一直安慰自己断盛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布愉舔。 她就那樣靜靜地躺著钢猛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪屑宠。 梳的紋絲不亂的頭發(fā)上厢洞,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音典奉,去河邊找鬼躺翻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛卫玖,可吹牛的內(nèi)容都是我干的公你。 我是一名探鬼主播,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼假瞬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼陕靠!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起脱茉,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤剪芥,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后琴许,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體税肪,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年榜田,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了益兄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡箭券,死狀恐怖净捅,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情辩块,我是刑警寧澤蛔六,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站庆捺,受9級(jí)特大地震影響古今,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜滔以,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望氓拼。 院中可真熱鬧你画,春花似錦抵碟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至适滓,卻和暖如春敦迄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背凭迹。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工罚屋, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人嗅绸。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓脾猛,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親鱼鸠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子猛拴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

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

  • 冒泡排序插入排序插入排序和冒泡排序分析 冒泡排序 冒泡排序(英語(yǔ):Bubble Sort,臺(tái)灣另外一種譯名為:泡沫...
    六尺帳篷閱讀 2,185評(píng)論 0 9
  • 概述:排序有內(nèi)部排序和外部排序蚀狰,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序愉昆,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部...
    每天刷兩次牙閱讀 3,732評(píng)論 0 15
  • 概述 排序有內(nèi)部排序和外部排序麻蹋,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序跛溉,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部...
    蟻前閱讀 5,186評(píng)論 0 52
  • 排序的基本概念 在計(jì)算機(jī)程序開發(fā)過(guò)程中哥蔚,經(jīng)常需要一組數(shù)據(jù)元素(或記錄)按某個(gè)關(guān)鍵字進(jìn)行排序倒谷,排序完成的序列可用于快...
    Jack921閱讀 1,433評(píng)論 1 4
  • 姓名:劉衛(wèi)師: 公司:寧波大發(fā)化纖有限公司 《六項(xiàng)精進(jìn)》289期反省二組紀(jì)律委員 【日精進(jìn)打卡第66天】 【知~學(xué)...
    劉偉師閱讀 198評(píng)論 0 0