java 实现最小二叉堆排序
来源:互联网 发布:mars软件官网 编辑:程序博客网 时间:2024/06/05 03:16
一觉醒来,我就突然有灵感了......
最小二叉堆定义:
二叉堆是完全二元树或者是近似完全二元树,最小二叉堆是父结点的键值总是小于或等于任何一个子节点的键值的堆堆。
存储:
二叉堆一般用数组来表示。
根节点在数组中的位置是0,第n个位置的子节点分别在2n+1和 2n+2;
位置k的叶子的父节点位置为(k-1)/2;
实现:
Java代码:
/**
* @description 元素添加到末尾,和它的父节点比,如果比它小就交换
* @param array
*
* @author LynnWong
*/
private int[] getMinBinaryHeap(int[] array){
int N = array.length;
int minBinaryHeap[] = new int[N];
int root;//根的值
int heapSize = 0;//记录插入位置
for(int num : array){
minBinaryHeap[heapSize]=num;
++heapSize;
int pointer = heapSize-1;//当前指向的数组元素位置
while(pointer!=0){
int leafPointer = pointer;//叶子节点位置
pointer = (pointer-1)/2;//根节点位置
root = minBinaryHeap[pointer];//根节点
if(num>=minBinaryHeap[pointer]){//永远把当前数组元素看成叶子与其根比较或者换位
break;
}//如果根比叶子大 就交换位置
minBinaryHeap[pointer] = num;
minBinaryHeap[leafPointer] = root;
}
}
return minBinaryHeap;
}
Java代码 :
/***
* 用随机数测试二叉堆排序
* 测试10遍,强迫症似的变态...
*/
public void text(){
for(int i=0;i<10;i++){
Random rnd = new Random();
int [] lala = {rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6)};
System.out.print("输入:");
for(int a : lala){
System.out.print(a+" ");
}
System.out.println();
int []array = this.getMinBinaryHeap(lala);
System.out.print("输出:");
for(int a : array){
System.out.print(a+" ");
}
System.out.println();
}
}
- java 实现最小二叉堆排序
- Java实现的堆排序(最小堆)
- java实现最小堆(通过构造函数构造最小堆,相当于堆排序)
- 数据结构二叉堆C++实现 最小堆
- Java最小堆实现
- java 堆排序代码(最小堆)
- c++实现二叉堆及堆排序
- 优先队列(二叉堆实现) + 堆排序
- 最小堆的java实现
- 最小堆的JAVA实现
- 最小堆的Java实现
- 堆排序Java实现
- 堆排序-java实现
- 堆排序 Java实现
- java实现堆排序
- java实现堆排序
- Java实现堆排序
- java实现堆排序
- mysql自动编号字段 分页查询
- 关于函数参数(void与空)
- 一键开关XCode调试打印信息
- SOAP 1.1与SOAP 1.2的区别
- Ext.Net 1.x_Ext.Net_实现百度文库的效果
- java 实现最小二叉堆排序
- 代理模式(Proxy)
- 【转】TVS参数
- 统计整数二进制表示中1的个数
- 题目1083: 堆栈的使用 吉林大学上机题
- SOAP 1.2
- 将整型数值存入到byte数组中
- ORA-12519: TNS:no appropriate service handler found 解决
- AX-WS与JAX-RPC