`
hengjie10
  • 浏览: 24170 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

插入排序

 
阅读更多
package cn.thj.algorithms;

import java.util.Arrays;

/**
 * @author 谭恒杰
 * 
 *         直接插入排序(Insertion Sort)的基本思想是:每次将一个待排序的记录,按其关键字大小插入
 *         到前面已经排好序的子序列中的适当位置,直到全部记录插入完成为止。
 *         算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。
 *              
 *         设数组为a[0…n-1]。
 *         1. 初始时,a[0]自成1个有序区,无序区为a[1..n-1]。令i=1
 *         2. 将a[i]并入当前的有序区a[0…i-1]中形成a[0…i]的有序区间。
 *         3. i++并重复第二步直到i==n-1。排序完成。
 */
public class InsertSort {
	public static void insertSort(int[] a) {
		for (int i = 1; i < a.length; i++) {  
			
			for (int j = i - 1; j >= 0 && a[j] > a[j + 1]; j--) {
				//执行交换
				int temp = a[j];
				a[j] = a[j + 1];
				a[j + 1] = temp;
			}
			
		}
	}

	public static void main(String[] args) {
		int[] a = { 33, 4, 3, 67, 99, 88, 23 };
		System.out.println("插入排序前");
		System.out.println(Arrays.toString(a));
		//排序
		insertSort(a);
		System.out.println("插入排序后");
		System.out.println(Arrays.toString(a));
	}

}


分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics