亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語(yǔ)言中的直接插入排序(帶圖詳細(xì))

 更新時(shí)間:2022年12月27日 09:07:28   作者:小陳沒煩惱  
這篇文章主要介紹了C語(yǔ)言中的直接插入排序(帶圖詳細(xì)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

什么是直接插入排序?

直接插入排序是一種最簡(jiǎn)單的排序方法,其基本操作是將需要排序的元素插入到已排好的有序表序列中,從而得到一個(gè)完整的有序序列。

算法思想

①將待排序序列分為兩部分,一部分有序一部分無(wú)序。

②我們把第一個(gè)元素看作有序序列,從第二個(gè)元素到最后為無(wú)序序列。

③將無(wú)序序列中每一個(gè)元素依次插入到有序序列的合適位置–從小到大(從大到?。?/p>

小陳沒煩惱

實(shí)例講解

我們有一個(gè)待排序序列為【3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48】

1、我們將第一個(gè)元素3看成已經(jīng)排序好的序列,即有序序列。

2、從第二個(gè)元素44到最后一個(gè)元素48我們看作為無(wú)序的的序列,即待排序的序列。

3、我們將待排序序列中的第一個(gè)元素【44】,插入到有序序列中。

①待排序元素【44】和有序序列中元素【3】進(jìn)行比較,【44】比【3】大則直接插入到有序序列中。

②此時(shí)有序序列為【3,44】,待排序序列為【38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48】

3、我們將待排序序列中的第一個(gè)元素【38】,插入到有序序列中。

①待排序元素【38】和有序序列中元素【44】進(jìn)行比較,【38】比【44】小,則將【44】向后移動(dòng),然后在將【38】和【3】進(jìn)行比較,【38】大于【3】則將元素【38】插入到【3】位置后。 

注意: 需要將待排序元素與有序序列中的每一個(gè)元素進(jìn)行比較。

②此時(shí)有序序列為【3,38,44】,待排序序列為【 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48】

4、然后按照以上操作,將待排序序列中的元素依次插入到有序列中。

小結(jié):

待排序元素比有序元素元素大則直接插入到該有序元素后,若小于有序元素則將該有序元素向后移動(dòng)。

算法分析

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

O(n2)

空間復(fù)雜度

O(1)

穩(wěn)定性

穩(wěn)定的排序算法,其穩(wěn)定性在于相同值的元素進(jìn)行插入排序完成后相對(duì)位置不發(fā)生改變。

代碼實(shí)現(xiàn)

#include<stdio.h>
void Print(int array[],int len){
	for(int i=0;i<len;i++){
		printf("%d ",array[i]);
	}
	printf("\n");
} 
/*直接插入排序*/
/*
*算法描述:
*1.將待排序序列分為兩部分,一部分有序一部分無(wú)序
*2.第一個(gè)元素為有序序列,從第二個(gè)元素到最后為無(wú)序序列 
*3.將無(wú)序序列中每一個(gè)元素依次插入到有序序列的合適位置--從小到大(從大到小) 
*合適的位置:待排序元素大于或等于(小于)該元素 
*/ 
void InsertSort(int array[],int len){
	int i,j;
	//第一個(gè)for循環(huán) 遍歷無(wú)序序列 
	for(i=1;i<len;i++){  //從數(shù)組的第二個(gè)元素開始依次遍歷無(wú)序序列 
	 	int tem = array[i];  //臨時(shí)保存將要排序的元素 
	 	//第二個(gè)for循環(huán)遍歷有序序列 
	 	for(j=i-1;tem<=array[j]&&j>=0;j--){  //將待排序元素依次和有序序列中的元素比較 
	 		//待排序元素 小于 有序序列中當(dāng)前元素時(shí) 將該元素后移
	 		array[j+1] = array[j];
	 	}
	array[j+1] = tem;  //待排序元素 大于 有序序列最后一個(gè)元素 直接將該元素插入到有序序列最后 
	}
	printf("\n排序完成!\n\n");
}

main(){ 
	int array[10] = {4,3,10,5,6,7,1,2,8,9} ;
	int len = sizeof(array) / sizeof(int);
	printf("初始序列:\n");
	Print(array,len);
	InsertSort(array,len);
	printf("排序后序列:\n");
	Print(array,len);
}

運(yùn)行結(jié)果

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • Qt中const?QString轉(zhuǎn)換?char?*可能的坑

    Qt中const?QString轉(zhuǎn)換?char?*可能的坑

    本文主要介紹了Qt中const?QString轉(zhuǎn)換?char?*可能的坑,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • C#開源類庫(kù)SimpleTCP使用方法

    C#開源類庫(kù)SimpleTCP使用方法

    SimpleTCP內(nèi)部有一個(gè)特殊字符分割字符串的協(xié)議可以直接使用,也可以在DataReceived事件處理程序中實(shí)現(xiàn)自己的協(xié)議,這篇文章主要介紹了C#開源類庫(kù)SimpleTCP的使用方法,需要的朋友可以參考下
    2021-09-09
  • C語(yǔ)言實(shí)現(xiàn)推箱子小游戲

    C語(yǔ)言實(shí)現(xiàn)推箱子小游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 利用C/C++二進(jìn)制讀寫png文件的方法示例

    利用C/C++二進(jìn)制讀寫png文件的方法示例

    最近在做項(xiàng)目的時(shí)候遇到了這個(gè)問(wèn)題,所以想著總結(jié)下,方法自己和有需要的朋友,下面這篇文章主要介紹了利用C/C++二進(jìn)制讀寫png文件的方法,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2016-12-12
  • C語(yǔ)言實(shí)現(xiàn)牛頓迭代法解方程詳解

    C語(yǔ)言實(shí)現(xiàn)牛頓迭代法解方程詳解

    這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)牛頓迭代法解方程詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • 深入分析C語(yǔ)言分解質(zhì)因數(shù)的實(shí)現(xiàn)方法

    深入分析C語(yǔ)言分解質(zhì)因數(shù)的實(shí)現(xiàn)方法

    這篇文章主要介紹了深入分析C語(yǔ)言分解質(zhì)因數(shù)的實(shí)現(xiàn)方法,作者結(jié)合了ACM題目作為相關(guān)拓展,需要的朋友可以參考下
    2015-08-08
  • C++處理輸入字符串并轉(zhuǎn)為數(shù)組的操作

    C++處理輸入字符串并轉(zhuǎn)為數(shù)組的操作

    這篇文章主要介紹了C++處理輸入字符串并轉(zhuǎn)為數(shù)組的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • 淺析C語(yǔ)言調(diào)試器GDB和LLDB的使用方法

    淺析C語(yǔ)言調(diào)試器GDB和LLDB的使用方法

    這篇文章主要介紹了C語(yǔ)言調(diào)試器GDB和LLDB的使用方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-12-12
  • C++11/14 線程調(diào)用類對(duì)象和線程傳參的方法

    C++11/14 線程調(diào)用類對(duì)象和線程傳參的方法

    這篇文章主要介紹了C++11/14 線程調(diào)用類對(duì)象和線程傳參的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • C語(yǔ)言數(shù)組按協(xié)議存儲(chǔ)與按協(xié)議解析數(shù)據(jù)的實(shí)現(xiàn)

    C語(yǔ)言數(shù)組按協(xié)議存儲(chǔ)與按協(xié)議解析數(shù)據(jù)的實(shí)現(xiàn)

    今天小編就為大家分享一篇關(guān)于C語(yǔ)言數(shù)組按協(xié)議存儲(chǔ)與按協(xié)議解析數(shù)據(jù)的實(shí)現(xiàn),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12

最新評(píng)論