欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言直接插入排序算法

 更新時間:2022年01月07日 09:47:43   作者:恒天1020  
大家好,本篇文章主要講的是C語言直接插入排序算法,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽

1.算法模板

void InsertSort(SqList *L)
{
    int j;
    for (int i = 2; i <= L->length; i ++ ) {
        if (L->arr[i] < L->arr[i-1])
        {
            L->arr[0] = L->arr[i];  // 設(shè)置哨兵
            for (j = i - 1; L->arr[j] > L->arr[0]; j -- )
                L->arr[j + 1] = L->arr[j];
            L->arr[j + 1] = L->arr[0];
        }
    }
}

2.算法介紹

直接插入排序的基本思想是:對于一個長度為n的序列,從第2的元素開始,逐個向之前排好的序列中插入新元素(第1個元素可以視為一個長度為1的有序的子序列),從而得到一個長度為n的有序的序列。

算法的時間復(fù)雜度為O(n^2),最好的情況為待排序列本身就是有序的,只需要遍歷一遍,時間復(fù)雜度為O(n),最壞的情況為逆序,時間復(fù)雜度為O(n*n),由于元素之間是逐個進行比較的,直接插入排序是一種穩(wěn)定的排序算法。

3.實例

#include <iostream>
using namespace std;

const int N = 100;

typedef struct
{
    int arr[N];
    int length;
} SqList;

void InsertSort(SqList *L)
{
    int j;
    for (int i = 2; i <= L->length; i ++ ) {
        if (L->arr[i] < L->arr[i-1])
        {
            L->arr[0] = L->arr[i];  // 設(shè)置哨兵
            for (j = i - 1; L->arr[j] > L->arr[0]; j -- )
                L->arr[j + 1] = L->arr[j];
            L->arr[j + 1] = L->arr[0];
        }
    }
}

int main()
{
    SqList L;
    L.arr[1] = 50;
    L.arr[2] = 10;
    L.arr[3] = 90;
    L.arr[4] = 30;
    L.arr[5] = 70;
    L.arr[6] = 40;
    L.arr[7] = 80;
    L.arr[8] = 60;
    L.arr[9] = 20;
    L.length = 9;

    InsertSort(&L);
    for (int i = 1; i <= L.length; i ++ )
        cout << L.arr[i] << " ";

}

總結(jié)

到此這篇關(guān)于C語言直接插入排序算法的文章就介紹到這了,更多相關(guān)C語言插入排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一文掌握scanf的用法實例小結(jié)

    一文掌握scanf的用法實例小結(jié)

    scanf的基本用法除了常規(guī)的輸入操作外還有一些特殊的用法,使用這些用法可以很方便的在輸入中讀取想要的數(shù)據(jù),這篇文章主要介紹了scanf的用法,需要的朋友可以參考下
    2023-12-12
  • C++直接cout指針名的含義?

    C++直接cout指針名的含義?

    今天小編就為大家分享一篇關(guān)于C++直接cout指針名的含義?,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • MFC擴展DLL中導(dǎo)出類和對話框的實現(xiàn)方法

    MFC擴展DLL中導(dǎo)出類和對話框的實現(xiàn)方法

    這篇文章主要介紹了MFC擴展DLL中導(dǎo)出類和對話框的實現(xiàn)方法,詳細講述了實現(xiàn)擴展DLL中導(dǎo)出類和對話框的具體步驟與方法,具有不錯的實用價值,需要的朋友可以參考下
    2014-10-10
  • C語言for循環(huán)嵌套for循環(huán)在實踐題目中應(yīng)用詳解

    C語言for循環(huán)嵌套for循環(huán)在實踐題目中應(yīng)用詳解

    初學(xué)C語言,常常遇到for循環(huán)中嵌套個for循環(huán),初學(xué)者對于這種形式總是一知半解,這次我就整理了常見的for循環(huán)嵌套for循環(huán)的題目,我們一起爭取一舉拿下這類題。學(xué)廢他們,以后再見到就不怕啦!每天都要學(xué)一點呀。加油,奮斗的我們
    2022-05-05
  • C語言實現(xiàn)自行車管理系統(tǒng)

    C語言實現(xiàn)自行車管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)自行車管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C++文件輸入輸出fstream使用方法

    C++文件輸入輸出fstream使用方法

    C++標準庫提供了<fstream>頭文件,其中包含了用于文件輸入輸出的相關(guān)類和函數(shù),本文將詳細介紹<fstream>頭文件的使用方法,包括函數(shù)原型、打開文件、讀取和寫入文件、以及錯誤處理等注意事項,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • 詳解C++之函數(shù)重載

    詳解C++之函數(shù)重載

    這篇文章主要介紹了c++函數(shù)重載的相關(guān)知識,文章講解的非常細致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • 基于大端法、小端法以及網(wǎng)絡(luò)字節(jié)序的深入理解

    基于大端法、小端法以及網(wǎng)絡(luò)字節(jié)序的深入理解

    本篇文章是對大端法、小端法以及網(wǎng)絡(luò)字節(jié)序進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++?指針常量和常量指針的區(qū)別小結(jié)

    C++?指針常量和常量指針的區(qū)別小結(jié)

    在C++學(xué)習(xí)使用過程中,每個人都不可避免地使用指針,而且都或多或少的接觸過常量指針或指針常量,本文主要介紹了C++?指針常量和常量指針的區(qū)別小結(jié),感興趣的可以了解一下
    2023-12-12
  • C語言矩陣連乘 (動態(tài)規(guī)劃)詳解

    C語言矩陣連乘 (動態(tài)規(guī)劃)詳解

    這篇文章主要介紹了C語言矩陣連乘 (動態(tài)規(guī)劃)詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05

最新評論