Java 直接插入排序

經(jīng)常碰到這樣一類排序問題:把新的數(shù)據(jù)插入到已經(jīng)排好的數(shù)據(jù)列中释移。

  1. 將第一個(gè)數(shù)和第二個(gè)數(shù)排序晴埂,然后構(gòu)成一個(gè)有序序列
  2. 將第三個(gè)數(shù)插入進(jìn)去,構(gòu)成一個(gè)新的有序序列田轧。
  3. 對(duì)第四個(gè)數(shù)、第五個(gè)數(shù)……直到最后一個(gè)數(shù)鞍恢,重復(fù)第二步傻粘。

如何寫寫成代碼:

  1. 首先設(shè)定插入次數(shù),即循環(huán)次數(shù)帮掉,for(int i=1;i<length;i++)弦悉,1個(gè)數(shù)的那次不用插入。
  2. 設(shè)定插入數(shù)和得到已經(jīng)排好序列的最后一個(gè)數(shù)的位數(shù)蟆炊。insertNum和j=i-1稽莉。
  3. 從最后一個(gè)數(shù)開始向前循環(huán),如果插入數(shù)小于當(dāng)前數(shù)涩搓,就將當(dāng)前數(shù)向后移動(dòng)一位污秆。
  4. 將當(dāng)前數(shù)放置到空著的位置,即j+1。
public void insertSort(int[] a){
        int length=a.length;//數(shù)組長(zhǎng)度,將這個(gè)提取出來是為了提高速度疮方。
        int insertNum;//要插入的數(shù)
        for(int i=1;i<length;i++){//插入的次數(shù)
            insertNum=a[i];//要插入的數(shù)
            int j=i-1;//已經(jīng)排序好的序列元素個(gè)數(shù)
            while(j>=0&&a[j]>insertNum){//序列從后到前循環(huán),將大于insertNum的數(shù)向后移動(dòng)一格
                a[j+1]=a[j];//元素移動(dòng)一格
                j--;
            }
            a[j+1]=insertNum;//將需要插入的數(shù)放在要插入的位置庸推。
        }
    }

?著作權(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)離奇詭異,居然都是意外死亡井厌,警方通過查閱死者的電腦和手機(jī)蚓庭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來仅仆,“玉大人器赞,你說我怎么就攤上這事∧拱荩” “怎么了港柜?”我有些...
    開封第一講書人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)咳榜。 經(jīng)常有香客問我夏醉,道長(zhǎng),這世上最難降的妖魔是什么涌韩? 我笑而不...
    開封第一講書人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任畔柔,我火速辦了婚禮,結(jié)果婚禮上臣樱,老公的妹妹穿的比我還像新娘靶擦。我一直安慰自己,他們只是感情好雇毫,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開白布玄捕。 她就那樣靜靜地躺著,像睡著了一般棚放。 火紅的嫁衣襯著肌膚如雪枚粘。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評(píng)論 1 285
  • 那天席吴,我揣著相機(jī)與錄音赌结,去河邊找鬼。 笑死孝冒,一個(gè)胖子當(dāng)著我的面吹牛柬姚,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播庄涡,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼量承,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起撕捍,我...
    開封第一講書人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤拿穴,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后忧风,有當(dāng)?shù)厝嗽跇淞掷锇l(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
  • 文/蒙蒙 一兑牡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧税灌,春花似錦均函、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至粘秆,卻和暖如春如迟,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背攻走。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工殷勘, 沒想到剛下飛機(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)容

  • 1.直接插入排序 我們經(jīng)常會(huì)到這樣一類排序問題:把新的數(shù)據(jù)插入到已經(jīng)排好的數(shù)據(jù)列中策吠。將第一個(gè)數(shù)和第二個(gè)數(shù)排序...
    小武_215e閱讀 83評(píng)論 0 2
  • 直接插入排序是一種最簡(jiǎn)單的排序算法,在后續(xù)我會(huì)繼續(xù)發(fā)布其他的簡(jiǎn)單排序瘩绒;直接插入的算法基本思想是:僅有一個(gè)元素的序列...
    牧歌_東閱讀 4,814評(píng)論 0 0
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 將一個(gè)記錄插入到已排序好...
    依依玖玥閱讀 1,239評(píng)論 0 2
  • 排序問題一直是程序員工作與面試的重點(diǎn)猴抹,今天特意整理研究下與大家共勉!這里列出8種常見的經(jīng)典排序锁荔,基本涵蓋了所有的排...
    依天立業(yè)閱讀 961評(píng)論 0 0
  • 今天阳堕,我閱讀了《鋼鐵是怎樣煉成的》第一章第十六坤溃、十七節(jié)。 好詞:署名 驚喜 談妥 血跡遍野 休...
    fac2a57fe714閱讀 1,940評(píng)論 0 0