关注
我也觉得有问题, 不过我的答案跟楼主也不同。。。附上我的答案:
好像牛客网目前有点小问题, 图片传不上来
我用数组的方式表示: 从A.length/2 = 8/2 = 4 也就是 数字1开始调整
45301726 -> 45301726 -> 45361720 -> 45761320 ->
46751320 -> 76451320
附上代码:
public int[] heapSort(int[] A, int n) {
for(int i=(n-1)/2;i>=0;--i){ //将数组初始化为堆
heapAdSort(A,i,n);
}
print(A);
//只要初始化部分,后面代码注释掉
/* for(int i=n-1;i>0;--i){
int temp = A[i];
A[i] = A[0];
A[0] = temp;
heapAdSort(A,0,i);
}
*/
return A;
}
public void heapAdSort(int[] A,int i,int
n){//A为数组,i为结点值,n为数组长度
int child = 2 * i + 1; //左孩子
int temp = A[i];//保存节点值
while(child < n){
if(child+1 < n && A[child] <
A[child+1]){// 把child节点指向左右孩子中较大的一个
child ++ ;
}
if(A[i] < A[child]){//如果节点小于孩子值,则交换,节点向下
A[i]=A[child];
i = child;
child = 2*i+1;
}else{
break;
}
A[i] = temp;//将节点保存;
}
}
public void print(int[] A){
for(int i:A){
System.out.print(i+" ");
}
System.out.println();
}
查看原帖
点赞 3
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 考研对你找工作产生了哪些影响? #
4953次浏览 58人参与
# 打杂的实习你会去吗? #
108628次浏览 949人参与
# 聊聊这家公司值得去吗 #
238913次浏览 2236人参与
# 机械只有读研才有出路吗? #
19860次浏览 228人参与
# 你认为哪个岗位找工作最卷 #
16486次浏览 66人参与
# 面试被问第一学历差时该怎么回答 #
130707次浏览 823人参与
# 远程面试的尴尬瞬间 #
100982次浏览 828人参与
# 硬件人绝对不能踩的坑 #
61315次浏览 736人参与
# kpi面有什么特征 #
35643次浏览 264人参与
# 工作中哪个瞬间让你想离职 #
24174次浏览 166人参与
# 如何缓解入职前的焦虑 #
187262次浏览 1319人参与
# 你有哪些缓解焦虑的方法? #
3361次浏览 130人参与
# 职场人,说说你的烦心事 #
9027次浏览 83人参与
# 实习生应该准时下班吗 #
223500次浏览 1398人参与
# 秋招最大的收获是什么? #
34200次浏览 301人参与
# 职场上哪些事情令人讨厌 #
16882次浏览 86人参与
# 为了找工作你投递了多少公司? #
12011次浏览 164人参与
# 你今年的平均薪资是多少? #
126729次浏览 661人参与
# 运营/市场营销人的秋招现状 #
17258次浏览 189人参与
# 担心入职之后被发现很菜怎么办 #
126906次浏览 760人参与