zoukankan      html  css  js  c++  java
  • Java八大基本排序之堆排序

    public class SortHeap {
    
    
        public static void sort(int[] data) {
    
            // 构建大顶堆
            for (int i = (data.length - 2) / 2; i >= 0; i--) {
                adjustHeap(data, i, data.length);
            }
    
            // 对顶元素与堆尾元素进行调整,重现调整堆为大顶堆
            for (int j = data.length - 1; j >= 0; j--) {
                int temp = data[j];
                data[j] = data[0];
                data[0] = temp;
                adjustHeap(data, 0, j);
            }
        }
    
        public static void adjustHeap(int[] data, int i, int length) {
            int temp = data[i];
            for (int k = i * 2 + 1; k < length; k = k * 2 + 1) {
                if (k + 1 < length && data[k] < data[k + 1]) { // 比较左孩子是否小于右孩子,如果小于,则直接比较右孩子
                    k++;
                }
                if (data[k] > temp) {
                    data[i] = data[k];
                    i = k;
                } else {
                    break;
                }
            }
            data[i] = temp;
        }
    
    
        public static void main(String[] args) {
    
            int data[] = {4, 5, 8, 1, 2, 3, 6, 7, 11, 10, 9};
    
            for (int i = 0; i < data.length; i++) {
                System.out.print(data[i] + "  ");
            }
            System.out.println();
            System.out.println("-----------------------------");
    
            sort(data);
            for (int i = 0; i < data.length; i++) {
                System.out.print(data[i] + "  ");
            }
            System.out.println();
        }
    
    
    }
    输出如下:
    4  5  8  1  2  3  6  7  11  10  9  
    -----------------------------
    1  2  3  4  5  6  7  8  9  10  11  
    
    Process finished with exit code 0
    

      

  • 相关阅读:
    5.基于文件验证的vsftp虚拟用户
    linux系统用户登录ftp
    4.ftp用户禁锢
    原码,反码,补码
    8map
    命令jhsdb jmap heap pid 1 报错
    20211112_mysql_8.0docker部署踩坑
    Windows 下 tail 查看日志命令工具分享
    前后端java+vue 实现rsa 加解密与摘要签名算法
    优化TTFB 至500ms内
  • 原文地址:https://www.cnblogs.com/wangxiaowang/p/12425839.html
Copyright © 2011-2022 走看看