插入排序

1. 基本定義

插入排序的代碼實(shí)現(xiàn)雖然沒(méi)有冒泡排序和選擇排序那么簡(jiǎn)單粗暴,但它的原理應(yīng)該是最容易理解的了,因?yàn)橹灰蜻^(guò)撲克牌的人都應(yīng)該能夠秒懂。

插入排序是一種最簡(jiǎn)單直觀的排序算法,它的工作原理是通過(guò)構(gòu)建有序序列坟岔,對(duì)于未排序數(shù)據(jù)豫缨,在已排序序列中從后向前掃描独令,找到相應(yīng)位置并插入。

插入排序和冒泡排序一樣好芭,也有一種優(yōu)化算法燃箭,叫做拆半插入。

  1. 算法步驟
    將第一待排序序列第一個(gè)元素看做一個(gè)有序序列舍败,把第二個(gè)元素到最后一個(gè)元素當(dāng)成是未排序序列招狸。

從頭到尾依次掃描未排序序列,將掃描到的每個(gè)元素插入有序序列的適當(dāng)位置邻薯。(如果待插入的元素與有序序列中的某個(gè)元素相等裙戏,則將待插入元素插入到相等元素的后面。)

2. 代碼

 public static void main(String[] args) {
        int[] arr = {3,5,8,6,2,4,9};

        int[] sortArr = sort(arr);
        for (int c : sortArr) {
            System.out.println(c);
        }
    }

    public static int[] sort(int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            // 記錄要插入的數(shù)據(jù)
            int tmp = arr[i];
            // 從已經(jīng)排序的序列最右邊的開(kāi)始比較厕诡,找到比其小的數(shù)
            int j = i;
            while (j > 0 && tmp < arr[j - 1]) {
                arr[j] = arr[j - 1];
                j--;
            }
            // 存在比其小的數(shù)累榜,插入
            if (j != i) {
                arr[j] = tmp;
            }
        }
        return arr;
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市灵嫌,隨后出現(xiàn)的幾起案子壹罚,更是在濱河造成了極大的恐慌,老刑警劉巖醒第,帶你破解...
    沈念sama閱讀 216,651評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渔嚷,死亡現(xiàn)場(chǎng)離奇詭異进鸠,居然都是意外死亡稠曼,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)客年,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)霞幅,“玉大人,你說(shuō)我怎么就攤上這事量瓜∷究遥” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,931評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵绍傲,是天一觀的道長(zhǎng)扔傅。 經(jīng)常有香客問(wèn)我,道長(zhǎng)烫饼,這世上最難降的妖魔是什么猎塞? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,218評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮杠纵,結(jié)果婚禮上荠耽,老公的妹妹穿的比我還像新娘。我一直安慰自己比藻,他們只是感情好铝量,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布倘屹。 她就那樣靜靜地躺著,像睡著了一般慢叨。 火紅的嫁衣襯著肌膚如雪纽匙。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,198評(píng)論 1 299
  • 那天拍谐,我揣著相機(jī)與錄音哄辣,去河邊找鬼。 笑死赠尾,一個(gè)胖子當(dāng)著我的面吹牛力穗,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播气嫁,決...
    沈念sama閱讀 40,084評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼当窗,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了寸宵?” 一聲冷哼從身側(cè)響起崖面,我...
    開(kāi)封第一講書(shū)人閱讀 38,926評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎梯影,沒(méi)想到半個(gè)月后巫员,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,341評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡甲棍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評(píng)論 2 333
  • 正文 我和宋清朗相戀三年简识,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片感猛。...
    茶點(diǎn)故事閱讀 39,731評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡七扰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出陪白,到底是詐尸還是另有隱情颈走,我是刑警寧澤,帶...
    沈念sama閱讀 35,430評(píng)論 5 343
  • 正文 年R本政府宣布咱士,位于F島的核電站立由,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏序厉。R本人自食惡果不足惜锐膜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望脂矫。 院中可真熱鬧枣耀,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,676評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至颅围,卻和暖如春伟葫,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背院促。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,829評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工筏养, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人常拓。 一個(gè)月前我還...
    沈念sama閱讀 47,743評(píng)論 2 368
  • 正文 我出身青樓渐溶,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親弄抬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子茎辐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評(píng)論 2 354

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