java 堆实现

java 堆实现

代码

public static void buildheap(int[] a , int heaplength) {
for(int i = a.length/2-1; i >= 0; i–)
{
heapify(a, i, heaplength);
}
}
//小顶堆
public static void heapify(int a[], int i, int heaplength) {
int min = i;
// System.out.println("i = " + i);
while(true)
{
int l = 2i + 1; //找到节点i 的左子节点
int r = 2
i + 2;
if(l < heaplength && a[l] < a[i])
{
min = l;
}
if(r < heaplength && a[r] < a[min])
{
min = r;
}
if(min == i) break;
int temp = a[i];
a[i] = a[min];
a[min] = temp;

i = min;
}
}

作者:yankuangshigo
链接:https://leetcode-cn.com/problems/kth-largest-element-in-an-array/solution/java-pai-xu-xiao-ding-dui-shi-xian-by-yankuangshig/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值