shell排序算法

    shell排序算法严格来说基于插入排序的思想,其又称为希尔排序或者缩小增量排序。shell排序算法的排序流程如下:
    1)将n个元素的数组分为n/2个数据序列,第一个数据和第n/2+1个数据为一对
    2)一次循环使每一个序列对应排好顺序
    3)然后,再变为n/4个序列,再次排序
    4)不断重复上述过程

    例如如下数据排序

    初始数据  127   118  105  101  112   100

    一次排序  101   112  100  127  118   105

    二次排序  100   101  105  112  118   127
   
    第一次排序 首先数组分为6/2=3 3个元素一组
    第二次排序 6/4=1(取整数) 每个逐个数据比较,采用插入算法进行

public class ShellSort {
	public static int count = 0;

	public static void main(String[] args) {

		int[] data = new int[] { 5, 3, 6, 2 };
		print(data);
		shellSort(data);
		print(data);

	}

	public static void shellSort(int[] data) {
		// 计算出最大的h值
		int h = 1;
		System.out.println(data.length / 3); 
		while (h <= data.length / 3) {
			h = h * 3 + 1;
		}
		while (h > 0) {
			for (int i = h; i < data.length; i += h) {
				if (data[i] < data[i - h]) {
					int tmp = data[i];
					int j = i - h;
					while (j >= 0 && data[j] > tmp) {
						data[j + h] = data[j];
						j -= h;
					}
					data[j + h] = tmp;
					print(data);
				}
			}
			// 计算出下一个h值
			h = (h - 1) / 3;
		}
	}

	public static void print(int[] data) {
		for (int i = 0; i < data.length; i++) {
			System.out.print(data[i] + "\t");
		}
		System.out.println();
	}
}

猜你喜欢

转载自luyulong.iteye.com/blog/2222564