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

C 語言插入排序算法及實例代碼

 更新時間:2016年07月18日 15:56:05   投稿:lqh  
本文主要介紹C語言插入排序,這里給大家詳細介紹插入排序的思想并舉例說明,還有實現(xiàn)代碼,有需要的朋友可以參考下

插入排序是排序算法的一種,它不改變原有的序列(數(shù)組),而是創(chuàng)建一個新的序列,在新序列上進行操作。

這里以從小到大排序為例進行講解。

基本思想及舉例說明

插入排序的基本思想是,將元素逐個添加到已經(jīng)排序好的數(shù)組中去,同時要求,插入的元素必須在正確的位置,這樣原來排序好的數(shù)組是仍然有序的。

在實際使用中,通常是排序整個無序數(shù)組,所以把這個無序數(shù)組分為兩部分排序好的子數(shù)組和待插入的元素。第一輪時,將第一個元素作為排序好的子數(shù)組,插入第二個元素;第二輪,將前兩個元素作為排序好的數(shù)組,插入第三個元素。以此類推,第i輪排序時,在前i個元素的子數(shù)組中插入第i+1個元素。直到所有元素都加入排序好數(shù)組。

下面,以對 3  2  4  1 進行選擇排序說明插入過程,使用j記錄元素需要插入的位置。排序目標是使數(shù)組從小到大排列。

第1輪

[ 3 ]  [ 2  4  1 ]  (最初狀態(tài),將第1個元素分為排序好的子數(shù)組,其余為待插入元素)
[ 3 ]  [ 2  4  1 ]  (由于3>2,所以待插入位置j=1)
[ 2  3 ]  [ 4  1 ]  (將2插入到位置j)

第2輪

[ 2  3 ]  [ 4  1 ] (第1輪排序結果)
[ 2  3 ]  [ 4  1 ] (由于2<4,所以先假定j=2)
[ 2  3 ]  [ 4  1 ] (由于3<4,所以j=3)
[ 2  3  4 ]  [ 1 ] (由于4剛好在位置3,無需插入)

第3輪

[ 2  3  4 ]  [ 1 ] (第2輪排序結果)
[ 2  3  4 ]  [ 1 ] (由于1<2,所以j=1)
[1  2  3  4 ]    (將1插入位置j,待排序元素為空,排序結束)

算法總結及實現(xiàn)

選擇排序?qū)Υ笮镹的無序數(shù)組R[N]進行排序,進行N-1輪選擇過程。首先將第1個元素作為已經(jīng)排序好的子數(shù)組,然后將剩余的N-1個元素,逐個插入到已經(jīng)排序好子數(shù)組;。因此,在第 i輪排序時,前i個元素總是有序的,將第i+1個元素插入到正確的位置。

#include<stdio.h>
#include<stdlib.h>
#define N 8
void insert_sort(int a[],int n);
//插入排序?qū)崿F(xiàn),這里按從小到大排序
void insert_sort(int a[],int n)//n為數(shù)組a的元素個數(shù)
{
 //進行N-1輪插入過程
 for(int i=1; i<n; i++)
 {
  //首先找到元素a[i]需要插入的位置
  int j=0;
  while( (a[j]<a[i]) && (j<i))
  {
   j++;
  }
  //將元素插入到正確的位置
  if(i != j) //如果i==j,說明a[i]剛好在正確的位置
  {
   int temp = a[i];
   for(int k = i; k > j; k--)
   {
    a[k] = a[k-1];
   }
   a[j] = temp;
  }
 }
}
int main()
{
 int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};
 insert_sort(num, N);
 for(int i=0; i<N; i++)
  printf("%d ", num[i]);
 printf("\n");
 system("pause");
 return 0;
}

注意:插入排序是一種穩(wěn)定的排序算法,不會改變原有序列中相同數(shù)字的順序。

插入排序是在一個已經(jīng)有序的小序列的基礎上,一次插入一個元素。當然,剛開始這個有序的小序列只有1個元素,就是第一個元素。比較是從有序序列的末尾開始,也就是想要插入的元素和已經(jīng)有序的最大者開始比起,如果比它大則直接插入在其后面,否則一直往前找直到找到它該插入的位置。如果碰見一個和插入元素相等的,那么插入元素把想插入的元素放在相等元素的后面。所以,相等元素的前后順序沒有改變,從原無序序列出去的順序就是排好序后的順序,所以插入排序是穩(wěn)定的。

以上就是對插入排序的詳細介紹,希望能幫助C語言開發(fā)的同學理解掌握插入排序。

相關文章

  • C++11生成隨機數(shù)(random庫)的使用

    C++11生成隨機數(shù)(random庫)的使用

    隨機數(shù)在很多地方都可以用到,本文主要介紹了C++11生成隨機數(shù)(random庫)的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C++中map和set的簡介及使用詳解

    C++中map和set的簡介及使用詳解

    本文主要介紹了C++中map和set的簡介及使用詳解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++學校運動會管理系統(tǒng)的實現(xiàn)

    C++學校運動會管理系統(tǒng)的實現(xiàn)

    這篇文章主要為大家詳細介紹了C++如何實現(xiàn)學校運動會管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • visual studio 2019編譯c++17的方法

    visual studio 2019編譯c++17的方法

    這篇文章主要介紹了visual studio 2019編譯c++17的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • C++ qt 使用jsoncpp json 讀寫操作

    C++ qt 使用jsoncpp json 讀寫操作

    JsonCpp是一個基于C++語言的開源庫,用于C++程序的Json數(shù)據(jù)的讀寫操作,本文重點給大家介紹C++ qt 使用jsoncpp json 讀寫操作,感興趣的朋友跟隨小編一起看看吧
    2021-11-11
  • C++ Boost Heap使用實例詳解

    C++ Boost Heap使用實例詳解

    Boost是為C++語言標準庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標準庫的后備,是C++標準化進程的開發(fā)引擎之一,是為C++語言標準庫提供擴展的一些C++程序庫的總稱
    2022-11-11
  • C++進階練習刪除鏈表的倒數(shù)第N個結點詳解

    C++進階練習刪除鏈表的倒數(shù)第N個結點詳解

    這篇文章主要給大家介紹了關于如何利用C++刪除鏈表的倒數(shù)第N個結點,文中通過實例代碼介紹的非常詳細,對大家學習或者使用C++具有一定的參考學習價值,需要的朋友可以參考下
    2022-05-05
  • C語言中數(shù)組排序淺析

    C語言中數(shù)組排序淺析

    這篇文章主要為大家介紹了C語言算法練習中數(shù)組元素排序的四種類型,文中的示例代碼講解詳細,對我們學習C語言有一定幫助,需要的可以參考一下
    2022-12-12
  • C語言實現(xiàn)字符串拼接和拷貝

    C語言實現(xiàn)字符串拼接和拷貝

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)字符串拼接和拷貝,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • C++模板類的用法實例

    C++模板類的用法實例

    這篇文章主要介紹了C++模板類的用法實例,以實例形式詳細講述了模板類的接口、成員、內(nèi)聯(lián)函數(shù)等概念及用法,需要的朋友可以參考下
    2014-10-10

最新評論