package com.wang.principle; public class Test2 { public static void main(String[] args) { int[] arr = {49, 38, 65, 97, 76, 13, 27, 50}; //int[] c = { 13, 38, 65, 97, 76, 13, 2, 50 };//稳定性判断 heapSort(arr); for (int i : arr) { System.out.print(i+" "); } } public static void heapSort(int[] arr) { if (arr == null && arr.length < 2) { return; } //先构建大顶堆 for (int i = 0; i < arr.length; i++) { headInsert(arr, i); } int size = arr.length; //每次选大顶堆root节点 size不断减1 swap(arr, 0, --size); while (size > 0) { headify(arr, 0, size); swap(arr, 0, --size); } } //上升 public static void headInsert(int[] arr, int cur) { while (arr[cur] > arr[(cur - 1) / 2]) { swap(arr, cur, (cur - 1) / 2); cur = (cur - 1) / 2; } } //下降 public static void headify(int[] arr, int index, int heapSize) { int left = index * 2 + 1; while (left < heapSize) { int largest = left + 1 < heapSize && arr[left + 1] > arr[left] ? left + 1 : left;//最大值下标 largest = arr[largest] > arr[index] ? largest : index; if (largest == index) { break; } swap(arr, largest, index); index = largest; left = index * 2 + 1; } } private static void swap(int[] arr, int x, int y) { int temp = arr[x]; arr[x] = arr[y]; arr[y] = temp; } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!