插入排序及优化

插入排序是一种比较简单而又神奇的排序算法,插入排序的基本思路简单,平均时间复杂度为O(n^2)。但是如果所排序数组是近乎有序的,则它的时间复杂度为O(n),这是高级排序算法也达不到的时间复杂度。代码如下:
public void insertionSort(int []a,int n)
	{
		for(int i=0;i<n;i++)//选择将要插入的数
		{
			for(int j=i;j>0;j--)//选择将要插入的地方
			{
				int k=0;
				if(a[j]<a[i])//交换位置
					k=a[j];
					a[j]=a[i];
					a[i]=k;
				else
					break;
			}
			
		}
	}
这段代码就是用java实现的插入排序的代码,这段代码可优化的地方就是在交换位置那一步,交换位置一共需要三次赋值,这是非常浪费时间的。可以考虑将选择插入
的数赋值给一个中间量,for循环向前遍历,判断该位置是否是应该插入的位置,如果不是就可以将数组向后移,如果是的话,就直接将该数插入合适位置。代码如下
public void insertionSort(int []a,int n)
	{
		for(int i=0;i<n;i++)
		{
			int e=a[i];
			int j=0;
			for(  j=i;j>0;j--)
			{
				 if(a[i]<a[j])
					 a[j]=a[j-1];
				 else
					 break;
			}
			a[j]=e;
		}
	}
这段代码将三次的赋值缩短到一次,可以将排序的速度大大缩短。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值