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

C++排序算法之插入排序解析

 更新時(shí)間:2023年10月31日 09:34:00   作者:大慶指針  
這篇文章主要介紹了C++排序算法之插入排序解析,將數(shù)組分為有序表和無(wú)序表,每次從有序表中取出一個(gè)元素,插入到有序表的適當(dāng)位置,每遍歷一次,有序表中元素增加一個(gè),無(wú)序表中元素個(gè)數(shù)減少一個(gè),重復(fù)n-1次,完成排序,需要的朋友可以參考下

C++插入排序

思想

將數(shù)組分為有序表和無(wú)序表,每次從有序表中取出一個(gè)元素,插入到有序表的適當(dāng)位置,剛開(kāi)始有序表中只有一個(gè)數(shù),無(wú)序表中有n-1個(gè)數(shù)。

每遍歷一次,有序表中元素增加一個(gè),無(wú)序表中元素個(gè)數(shù)減少一個(gè),重復(fù)n-1次,完成排序。

代碼

#include<iostream>
#include<vector>
using namespace std;
void insertSort(vector<int>&vec, int n)
{
	//j表示無(wú)序表第一個(gè)元素下標(biāo)
	for (int j = 1; j <n; j++)
	{
		//i表示有序表最后一個(gè)元素下標(biāo)
		for (int i = j - 1; i >= 0; i--)
		{
			if (vec[i] > vec[i + 1])
			{
				swap(vec[i], vec[i + 1]);
			}
		}
	}
}
int main()
{
	vector<int>vec = { 2,3,5,8,9,7,4,6,1 };
	insertSort(vec, vec.size());
	for (auto it : vec)
	{
		cout << it << " ";
	}
	return 0;
}

解析

時(shí)間復(fù)雜度:

最好時(shí)間復(fù)雜度(全部有序):O(n)

比較n-1趟,每一趟比較一次,不移動(dòng)元素,最好時(shí)間復(fù)雜度為O(n)

最壞時(shí)間復(fù)雜度(全部逆序):O(n2)

第一次排序時(shí)有序表1個(gè)元素,無(wú)序表n-1個(gè)元素,比較1次,移動(dòng)1次

第二次排序時(shí)有序表2個(gè)元素,無(wú)序表n-2個(gè)元素,比較2次,移動(dòng)2次

...

第n-1次排序時(shí)有序表n-1個(gè)元素,無(wú)序表1個(gè)元素,比較n-1次,移動(dòng)n-1次

故最壞時(shí)間復(fù)雜度為O((1+2+3+...+n-1)*2)=O(n*(n-1))=O(n2)

空間復(fù)雜度:

在原數(shù)組上操作,即使用了常數(shù)級(jí)空間O(1)

穩(wěn)定性:穩(wěn)定

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

相關(guān)文章

  • C語(yǔ)言示例講解switch分支語(yǔ)句的用法

    C語(yǔ)言示例講解switch分支語(yǔ)句的用法

    這篇文章主要為大家介紹了switch語(yǔ)句,switch語(yǔ)句是我們常見(jiàn)會(huì)用到的結(jié)構(gòu),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • C語(yǔ)言實(shí)現(xiàn)數(shù)組的循環(huán)移位的方法示例

    C語(yǔ)言實(shí)現(xiàn)數(shù)組的循環(huán)移位的方法示例

    這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)數(shù)組的循環(huán)移位的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 2048小游戲C語(yǔ)言實(shí)現(xiàn)代碼

    2048小游戲C語(yǔ)言實(shí)現(xiàn)代碼

    這篇文章主要為大家詳細(xì)介紹了2048小游戲C語(yǔ)言實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • MFC實(shí)現(xiàn)連連看游戲之消子算法

    MFC實(shí)現(xiàn)連連看游戲之消子算法

    這篇文章主要為大家詳細(xì)介紹了MFC實(shí)現(xiàn)連連看游戲之消子算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • c++算法進(jìn)階刪除有序鏈表中的重復(fù)元素

    c++算法進(jìn)階刪除有序鏈表中的重復(fù)元素

    這篇文章主要為大家介紹了c++算法進(jìn)階刪除有序鏈表中的重復(fù)元素示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • C語(yǔ)言實(shí)現(xiàn)關(guān)機(jī)小程序

    C語(yǔ)言實(shí)現(xiàn)關(guān)機(jī)小程序

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)關(guān)機(jī)小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • VC實(shí)現(xiàn)對(duì)話框窗口任意分割

    VC實(shí)現(xiàn)對(duì)話框窗口任意分割

    最近寫(xiě)MFC的程序,想在對(duì)話框里實(shí)現(xiàn)窗口的任意分割?,F(xiàn)在網(wǎng)絡(luò)資料一大抄,找個(gè)東西實(shí)在麻煩??偹氵@個(gè)很簡(jiǎn)單,很快就搞定了,寫(xiě)下來(lái)做個(gè)筆記。
    2015-06-06
  • C語(yǔ)言 module_init函數(shù)與initcall案例詳解

    C語(yǔ)言 module_init函數(shù)與initcall案例詳解

    這篇文章主要介紹了C語(yǔ)言 module_init函數(shù)與initcall案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 一文詳解Qt中線程的實(shí)際應(yīng)用

    一文詳解Qt中線程的實(shí)際應(yīng)用

    為了讓程序盡快響應(yīng)用戶操作,在開(kāi)發(fā)應(yīng)用程序時(shí)經(jīng)常會(huì)使用到線程。這篇文章就來(lái)和大家介紹一下Qt中線程的實(shí)際應(yīng)用,感興趣的小伙伴可以了解一下
    2023-03-03
  • C語(yǔ)言實(shí)現(xiàn)萬(wàn)年歷效果

    C語(yǔ)言實(shí)現(xiàn)萬(wàn)年歷效果

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)萬(wàn)年歷效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11

最新評(píng)論