package org.myorg.algorithm;
public class HeapSorter {
public static void heapSort(int[] array){
buildHeap(array);//构建堆
int n = array.length;
int i=0;
for(i=n-1;i>=1;i--){
swap(array,0,i);
heapify(array,0,i);
}
}
public static void buildHeap(int[] array){
int n = array.length;//数组中元素的个数
for(int i=n/2-1;i>=0;i--)
heapify(array,i,n);
}
public static void heapify(int[] A,int idx,int max){
int left = 2*idx+1;// 左孩子的下标(如果存在的话)
int right =2*idx+2;// 右孩子的下标(如果存在的话)
int largest = 0;//寻找3个节点中最大值节点的下标
if(leftA[idx])
largest = left;
else
largest = idx;
if(rightA[largest])
largest = right;
if(largest!=idx){
swap(A,largest,idx);
heapify(A,largest,max);
}
}
public static void swap(int[] array,int i,int j){
int temp =0;
temp=array[i];
array[i]=array[j];
array[j]=temp;
}
public static void main(String[] args) {
int[] a = {1,2,3,4,5,6,7,16,9,10,11,12,13,14,15,8};
System.out.println("排序前..........................");
for(int i=0;i
System.out.println(a[i]);
heapSort(a);
System.out.println("排序后..........................");
for(int i=0;i
System.out.println(a[i]);
}
}
如果觉得《堆排序算法的java实现_堆排序算法的JAVA实现》对你有帮助,请点赞、收藏,并留下你的观点哦!