直接插入排序

插入排序:對一個擁有n個記錄的有序序列旬蟋,插入一個記錄后油昂,得到一個記錄為n+1的有序序列的過程。
其中 n>=1;
我們升序排序

65FDF4A3-8817-4137-AF52-A83F8D1956D3.png

不斷將后續(xù)的每個記錄插入到已經(jīng)排好序的序列之中咖为,使之成為新的有序系列

#define N 10
static int array[N] ={0};

#pragma mark--插入排序 升序排序
void insertSort(int a[],int n){
    int i = 1;
    int j = 0;                         //代價       次數(shù)
    int temp = 0;
    for (; i< n; i++) {                //c1        n-1
        
        if (a[i]<a[i-1]) {             //c2        n-1
            
            j = i-1;                   //c3        n-1
            
            //a[i]待插入的數(shù)
            temp = a[i];//存儲較小的數(shù)   //c4        n-1
            
    //每一個記錄都和這個待插入的記錄比較                //n-1
    while (j>=0&&a[j]>temp) {          //c5      // ∑j   //∑求和符號 j的取值范圍[0,n-1]
                                                 //j=0
        

                                                 //n-1
                a[j+1] =a[j];         //c6          ∑j
                                                 //j=0
        
        
                                                // n-1
                j--;                  //c7      //  ∑j
                                                // j=0
            }
            a[j+1] = temp;            //c8          n-1

        }
    }
    
}
/*
                                                        n-1
      T(n) = c1(n-1) +c2(n-1)+c3(n-1)+c4(n-1) +(c5+c6+c7)∑j + c8(n-1)
                                                        j=0
 
      當(dāng)?shù)趙hile行代碼對每個j = 0,1,2...,n-1時秕狰,始終有a[j]>=temp,則是最佳情況,∑求和公式中j=1;
 
     從而得 T(n) = (c1+c2+c3+c4+c5+c6+c7+c8)(n-1) 
 
                = (c1+c2+c3+c4+c5+c6+c7+c8)n -(c1+c2+c3+c4+c5+c6+c7+c8)
 
        可以表示為=an+b  它是n的線性函數(shù)   時間復(fù)雜度O(n)
        
        所以當(dāng)序列基本有序時躁染,應(yīng)采用直接插入排序
 
        當(dāng)?shù)趙hile行代碼對每個j = 0,1,2...,n-1時鸣哀,始終有a[j]<temp,則是最壞情況,∑求和公式中(c5+c6+c7)(n-1)*n/2
 
      最后整理得 T(n) = an^2 +bn+c ,它是n的二次函數(shù)  時間復(fù)雜度O(n^2)
 
 */
#pragma mark --打印數(shù)組元素
void print(int a[],int n){
    
    printf("\n");
    for (int i = 0; i<n; i++) {
        
        printf("%5d",a[i]);
    }
    printf("\n");
}
#pragma mark--產(chǎn)生隨機(jī)數(shù)組
void randomArray(){
    
    for (int i = 0; i < N ; i++) {
        
        array[i] = arc4random()%N;
    }
}

main函數(shù)調(diào)用如下:

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        // insert code here...
        NSLog(@"Hello, World!");
        randomArray();
        printf("排序前\n");
        print(array, N);
        insertSort(array, N);
        printf("排序后\n");
        print(array, N);
        
    }
    return 0;
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吞彤,一起剝皮案震驚了整個濱河市我衬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌饰恕,老刑警劉巖挠羔,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異埋嵌,居然都是意外死亡破加,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門雹嗦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來范舀,“玉大人合是,你說我怎么就攤上這事《Щ罚” “怎么了聪全?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長辅辩。 經(jīng)常有香客問我难礼,道長,這世上最難降的妖魔是什么玫锋? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任蛾茉,我火速辦了婚禮,結(jié)果婚禮上景醇,老公的妹妹穿的比我還像新娘臀稚。我一直安慰自己,他們只是感情好三痰,可當(dāng)我...
    茶點故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著窜管,像睡著了一般散劫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上幕帆,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天获搏,我揣著相機(jī)與錄音,去河邊找鬼失乾。 笑死常熙,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的碱茁。 我是一名探鬼主播裸卫,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼纽竣!你這毒婦竟也來了墓贿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蜓氨,失蹤者是張志新(化名)和其女友劉穎聋袋,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體穴吹,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡幽勒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了港令。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片啥容。...
    茶點故事閱讀 40,144評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡棘钞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出干毅,到底是詐尸還是另有隱情宜猜,我是刑警寧澤,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布硝逢,位于F島的核電站姨拥,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏渠鸽。R本人自食惡果不足惜叫乌,卻給世界環(huán)境...
    茶點故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望徽缚。 院中可真熱鬧憨奸,春花似錦、人聲如沸凿试。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽那婉。三九已至板甘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間详炬,已是汗流浹背盐类。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留呛谜,地道東北人在跳。 一個月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像隐岛,于是被迫代替她去往敵國和親猫妙。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,092評論 2 355

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