堆排序(初始化——>排序)

堆排序是一种基于完全二叉树的排序算法,分为大根堆和小根堆。该算法利用堆的特性进行数据选择与排序。本文介绍了堆的定义、特点,并通过图解和代码展示了堆排序的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

堆的介绍

来源百度百科:

堆排序(Heapsort)是指利用堆积树(堆)这种数据结构所设计的一种排序算法,它是选择排序的一种。可以利用数组的特点快速定位指定索引的元素。堆分为大根堆和小根堆,是完全二叉树

堆排序是将数据看成是完全二叉树,根据完全二叉树的特性来进行排序的一种算法。

  • 完全二叉树: 除了最后一层之外的其他每一层都被完全填充,并且所有结点都保持向左对齐
  • 满二叉树:除了叶子结点之外的每一个结点都有两个孩子,每一层(当然包含最后一层)都被完全填充
  • 完满二叉树:除了叶子结点之外的每一个结点都有两个孩子结点。

下面用图来说话:

  • 完全二叉树(Complete Binary Tree):

  • 满二叉树(Perfect Binary Tree):

  • 完满二叉树(Full Binary Tree):

参考资料:

图解

代码

public class HeapDemo {

	public static void main(String[] args) {
		
		int arr[]= {36,5,69,6,8,-4,1};
		for(int x:arr) {
			System.out.print(x+",");
		}
		System.out.println();
		headSort(arr);
		for(int x:arr) {
			System.out.print(x+",");
		}
	}
	

	/**
     * 	堆排序
     */
    public static void headSort(int[] arr) {
        //构造初始堆,从第一个非叶子节点开始调整,左右孩子节点中较大的交换到父节点中
        for (int i = (arr.length) / 2 - 1; i >= 0; i--) {
        	headAdjust(arr, arr.length, i);
        }
        
        //排序,将最大的节点放在堆尾,然后从根节点重新调整
        for (int i = arr.length - 1; i >= 1; i--) {
            int temp = arr[0];
            arr[0] = arr[i];
            arr[i] = temp;
            headAdjust(arr, i, 0);
        }
    }
    
    private static void headAdjust(int[] arr, int len, int i) {
        int k = i, temp = arr[i], index = 2 * k + 1;
        while (index < len) {
            if (index + 1 < len) {
                if (arr[index] < arr[index + 1]) {
                    index = index + 1;
                }
            }
            if (arr[index] > temp) {
                arr[k] = arr[index];
                k = index;
                index = 2 * k + 1;
            } else {
                break;
            }
        }
        arr[k] = temp;
    }
}

此文仅为个人笔记,理解有限,欢迎留言指正。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值