堆排序代码

堆排序

堆排序代码如下:

	public static void main(String[] args) {
		System.out.println("原数组:");
		int[] arr = { 10, 8, 15, 16, 6, 9, 1, 7, 11, 20, 12, 5 };//示例数组
		System.out.println(Arrays.toString(arr));
		
		// 定义开始调整的位置
		int startNode = (arr.length - 1) / 2;
		for (int i = startNode; i >= 0; i--) {
			getArrayToHeap(arr, arr.length, i);
		}
		// 调整为大顶推的数组
		System.out.println("大顶推数组:" + "\n" + Arrays.toString(arr));
		
		//对大顶堆进行排序,把堆的根元素和最后一个元素进行调换
		for (int i = arr.length-1; i > 0 ; i--) {
			int temp = arr[i];
			arr[i] = arr[0];
			arr[0] = temp;
			getArrayToHeap(arr, i, 0);
		}
		System.out.println("最终的堆排序:" + "\n" + Arrays.toString(arr));
	}

	/**
	 * 创立一个数组转堆的方法(大顶推)
	 * 
	 * @param arr   需要调整的数组
	 * @param a     数组中元素的个数
	 * @param index 开始调整的位置
	 */
	public static void getArrayToHeap(int[] arr, int a, int index) {
		// 获取左右节点的位置
		int liftNode = 2 * index + 1;
		int rightNode = 2 * index + 2;
		// 查找最大节点对应的位置
		int maxNode = index;
		if (liftNode < a && arr[liftNode] > arr[maxNode]) {
			maxNode = liftNode;
		}
		if (rightNode < a && arr[rightNode] > arr[maxNode]) {
			maxNode = rightNode;
		}
		// 对最大节点进行调换位置
		if (maxNode != index) {
			int temp = arr[maxNode];
			arr[maxNode] = arr[index];
			arr[index] = temp;
			// 防止调整后的堆不是大顶堆,重新调用方法
			getArrayToHeap(arr, a, maxNode);
		}
	}

输出结果:

原数组:
[10, 8, 15, 16, 6, 9, 1, 7, 11, 20, 12, 5]
大顶推数组:
[20, 16, 15, 11, 12, 9, 1, 7, 10, 6, 8, 5]
最终的堆排序:
[1, 5, 6, 7, 8, 9, 10, 11, 12, 15, 16, 20]

注意:在查找最大节点的时候,if语句里如果不加入 liftNode < a 和 rightNode < a ,那么在节点增多的情况下,会出现数组索引越界异常:java.lang.ArrayIndexOutOfBoundsException

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值