排序之插入排序

原创 2015年11月20日 10:44:52
insertion sorting
有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,要求插入此数据后,序列仍然有序。
每次插入一个数据,就需要和序列中的其他数据作比较,所以时间复杂度是O(n^2)。这么大的时间复杂度,很明显这个排序适合用来做少量数据的排序。
插入排序是稳定排序,也就是说,两个相同元素,在排序后前后没发生变化。
最差情况:反序,需要移动n*(n-1)/2个元素 。
最好情况:正序,不需要移动元素。

空间复杂度是O(1).

#include<iostream>

using namespace std;
/*****
function insertsort to sort
********/ 
void insertsort(int a[],int n)
{
	for(int i = 0; i < n; i++)
	{
		//the value of a[i] will be changed ,so record it in tmp
		int tmp = a[i],j = i;
		//make a space for the new element
		while(j > 0 && a[j - 1] > tmp)
		{
			a[j] = a[j - 1];
			j--;
		}
		//insert the number to the ordered list
		a[j] = tmp;
	}
}
/*****
main function to check
********/ 
int main()
{
	int n,a[101];
	cin>>n;
	
	for(int i =0; i < n; i++)
	{
		cin>>a[i];
	}
		
	insertsort(a,n);
	
	for(int i =0; i < n; i++)
	{
		cout<<a[i]<<" ";
	}
	cout<<endl;
	return 0;
} 


版权声明:本文为博主原创文章,未经博主允许不得转载。

C++实现插入排序

  • 2017年11月02日 22:26
  • 712B
  • 下载

新手学习数据结构与算法---直接插入排序

直接插入排序: 时间复杂度:O(n^2) 一步一步记录自己成长的点滴,欢迎大家的建议。 //插入排序算法,以数组为实例,主要先理解算法 #include #define MAX 11...
  • zsjgs
  • zsjgs
  • 2011年10月16日 10:12
  • 374

插入排序(C语言实现)

  • 2014年11月30日 16:12
  • 926B
  • 下载

宁波赛 2010 T3 插入排序 线段树

【题目描述】     有依次排列的一列数a1,a2,a3,…,an-1,an。你可以随便把一个数拿出,插到最前面(当前第1个数a1前)、最后面(当前最后一个数an后面)、或者剩余数列中任意的相邻两个数...

插入排序的方法

  • 2013年07月10日 12:12
  • 31KB
  • 下载

直接插入排序的C实现

  • 2013年05月16日 11:20
  • 495B
  • 下载

c语言练习 插入排序 gcd求解

12月7随笔else if 语句使用时注意在判断中只进入一次。if(year % 4 ==0){ if(year % 100!= 0) } else if(year % 400 ==0) ...

插入排序源代码

  • 2013年07月31日 08:39
  • 585B
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:排序之插入排序
举报原因:
原因补充:

(最多只允许输入30个字)