歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

插入排序的思想與實現InsertSort

簡單來說,插入排序的思想是將待排序數列(這裡用數組表示)分為已排好序和未排好序的兩部分,一般將前面先排有序,例如:a[0]...a[i]已經有序,剩下的任務就是將a[i+1]...依次插入到前面有序的數列中,並同時使前面的序列仍然有序。

插入排序的開銷主要在:找待插入的位置。最壞的情況是原序列是逆序的,每次都要找到最前,開銷是 1+2+3+...n-1=n*(n-1)/2,故時間復雜度是O(n*n).

在插入的過程中還需要平移前面的數列。但是這個時間開銷是伴隨尋找插入位置同時進行的。下面是一段代碼,包含測試代碼,可直接運行。

#include "stdafx.h"
#include"iostream"
using namespace std;
int* insertsort(int a[],int m);
int _tmain(int argc, _TCHAR* argv[])
{
 int a[5]={1,3,4,2,0};
 cout<<"Please input five numbers:"<<endl;
 for(int i=0;i<5;i++)
 {
  cin>>a[i];
 }
 int *c=insertsort(a,5);
 for(int i=0;i<5;i++)
  cout<<*(c+i)<<endl;
 cout<<"finished input";
 return 0;
}
int*  insertsort(int a[],int m)
{
 for(int i=0;i<m-1;i++)  // i從0開始到i-1,j從i+1開始,到m
 {
  int j=i+1;  //從i後面的第一個元素開始一次向前進行比較
  int temp=a[j];//這一步是為了保存a[j]的值以便之後進行交換,否則有可能會被a[i]覆蓋
  while(i>=0&&temp<a[i])
  {
   a[i+1]=a[i]; //否的話因為需要將a[i]往後移位
   i--;//繼續往前比較
   
  }
  ///退出循環要麼是找到了比a[j]小的a[i],那麼從這個i+1到j-1的位置均後移了,所以要將temp賦值給a[i+1];
  //第二種情況是i已經減小到-1,所以將temp直接插到a[0]
  a[i+1]=temp;
 }
 return a;
}

Copyright © Linux教程網 All Rights Reserved