插入语排序

package 排序;

/**
 * 
 * @author 赵鹏
 * @date 2013年12月20日
 * 插入排序
 * 生活思想:类似于斗地主叫牌阶段,每拿到一张牌将拿到的牌和手中已经排序的牌从右向左(左为小,右为大)每一张牌进行比较,
 * 		    如果当前的牌比拿到的牌大就把牌向后挪到一个位置,直到当前的牌比拿到的牌小,就结束比较把拿到的牌插入到当前牌后面一个位置
 * 
 * 算法思想:array[0]自成一个有序区,无序区为array[1..n-1]
 * 		     将temp=array[i]和有序区的每个位置(array[j])从右向左进行比较,如果temp<array[j]将array[j]右移,
 *        如果发现array[j]<temp,则将temp插入到array[j+1]
 * 
 * 转载解说:
 * @see http://fei-cool.blog.sohu.com/152000311.html
 * 插入排序是在一个已经有序的小序列的基础上,一次插入一个元素。当然,刚开始这个有序的小序列只有1个元素,就是第一个元素。
 * 比较是从有序序列的末尾开始,也就是想要插入的元素和已经有序的最大者开始比起,如果比它大则直接插入在其后面,
 * 否则一直往前找直到找到它该插入的位置。如果碰见一个和插入元素相等的,那么插入元素把想插入的元素放在相等元素的后面。
 * 所以,相等元素的前后顺序没有改变,从原无序序列出去的顺序就是排好序后的顺序,所以插入排序是稳定的。
 */
public class InserSort
{
	
	/**
	 * 平均时间102
	 * @param array
	 */
	public static void sort(int[] array)
	{
		int i,j,temp;
		for(j=1;j<array.length;j++)
		{
			temp=array[j];
			i=j-1;
			while(i>=0&&array[i]>temp)
			{
				array[i+1]=array[i];
				i--;
			}
			array[i+1]=temp;
		}
	}
	
	/**
	 * 每比较一次,移动一次
	 * @param array
	 * 平均时间61
	 */
	public static void sort1(int[] array)
	{
		int i,j,temp;
		for(i=1;i<array.length;i++)
		{
			temp=array[i];
			for(j=i-1;j>=0&&array[j]>temp;j--)
			{
				array[j+1]=array[j];
			}
			array[j+1]=temp;
		}
	}
	
	/**
	 * 先找出插入的确切位置,然后一次性整体移动,再插入
	 * @param array
	 * 平均时间101
	 */
	public static void sort2(int[] array)
	{
		int i,j,k,temp;
		for(i=1;i<array.length;i++)
		{
			for(j=i-1;j>=0;j--)
			{
				if(array[j]<array[i])
					break;
			}
			if(j!=i-1)
			{
				temp=array[i];
				for(k=i-1;k>j;k--)
					array[k+1]=array[k];
				array[j+1]=temp;
			}
		}
	}
	
	/**
	 * 测试
	 * @param args
	 */
	public static void test(int[] testarray,int testcount)
	{
		long sum=0,temp;
		for(int i=1;i<=testcount;i++)
		{
			int[] t=testarray.clone();
			long begin1=System.currentTimeMillis();
			sort(t);
			long end1=System.currentTimeMillis();
			//System.out.println(Arrays.toString(a));
			temp=end1-begin1;
			if(i>5) sum+=temp;
			//System.out.println("time"+i+":"+temp);
		}
		System.out.println("InsertSort.sort()\taveg:"+(sum/(testcount-5)));
	}
	
	public static void test1(int[] testarray,int testcount)
	{
		long sum=0,temp;
		for(int i=1;i<=testcount;i++)
		{
			int[] t=testarray.clone();
			long begin1=System.currentTimeMillis();
			sort1(t);
			long end1=System.currentTimeMillis();
			//System.out.println(Arrays.toString(a));
			temp=end1-begin1;
			if(i>5) sum+=temp;
			//System.out.println("time"+i+":"+temp);
		}
		System.out.println("InsertSort.sort1()\taveg:"+(sum/(testcount-5)));
	}
	
	public static void test2(int[] testarray,int testcount)
	{
		long sum=0,temp;
		for(int i=1;i<=testcount;i++)
		{
			int[] t=testarray.clone();
			long begin1=System.currentTimeMillis();
			sort2(t);
			long end1=System.currentTimeMillis();
			//System.out.println(Arrays.toString(a));
			temp=end1-begin1;
			if(i>5) sum+=temp;
			//System.out.println("time"+i+":"+temp);
		}
		System.out.println("InsertSort.sort2()\taveg:"+(sum/(testcount-5)));
	}
}
点赞