今天不想跑,所以才去跑|

凉白茶

园龄:2年4个月粉丝:19关注:7

2023-03-19 10:57阅读: 15评论: 0推荐: 0

堆排序

堆排序

堆排序(Heap Sort)是一种树形选择排序,是对直接选择排序的有效改进,利用了堆的性质对要排序的数据进行排序。

堆排序的基本思想是:将待排序序列构造成一个大顶堆,此时整个序列的最大值就是堆顶的根节点。将其与末尾元素进行交换,此时末尾就为最大值。然后将剩余n-1个元素重新构造成一个堆,如此反复执行,便能得到一个有序序列了。

堆排序的时间复杂度为O(nlogn),空间复杂度为O(1)。

以下是Java代码的演示,实现了一个数组的堆排序。

代码演示:

class Solution {
public int[] sortArray(int[] nums) {
heap_sort(nums, nums.length);
return nums;
}
/*
* 维护大顶堆的性质
* @param nums 存储堆的数组
* @param n 数组的长度
* @param i 被维护节点的下标
*/
public void heapify(int[] nums, int n, int i) {
int largest = i;
int lson = i * 2 + 1;//索引为i的左孩子
int rson = i * 2 + 2;//索引为i的右孩子
if(lson < n && nums[lson] > nums[largest]){
largest = lson;
}
if(rson < n && nums[rson] > nums[largest]){
largest = rson;
}
if(largest != i){
//交换两个元素的值
int temp = nums[largest];
nums[largest] = nums[i];
nums[i] = temp;
heapify(nums, n, largest);
}
}
//堆排序入口
public void heap_sort(int[] nums, int n){
//建堆
for(int i = n/2 - 1; i >= 0; i--){
//自底逐层向上维护
heapify(nums, n, i);
}
//排序
for(int i = n - 1; i > 0; i--){
int temp = nums[0];
nums[0] = nums[i];
nums[i] = temp;
heapify(nums, i, 0);
}
}
}

本文作者:凉白茶

本文链接:https://www.cnblogs.com/zh-Note/p/17232606.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   凉白茶  阅读(15)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 404 not found REOL
404 not found - REOL
00:00 / 00:00
An audio error has occurred.

作曲 : Reol

作词 : Reol

fade away...do over again...

fade away...do over again...

歌い始めの一文字目 いつも迷ってる

歌い始めの一文字目 いつも迷ってる

どうせとりとめのないことだけど

伝わらなきゃもっと意味がない

どうしたってこんなに複雑なのに

どうしたってこんなに複雑なのに

噛み砕いてやらなきゃ伝わらない

ほら結局歌詞なんかどうだっていい

僕の音楽なんかこの世になくたっていいんだよ

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

僕は気にしない 君は気付かない

何処にももういないいない

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

忘れていく 忘れられていく

We don't know,We don't know.

目の前 広がる現実世界がまた歪んだ

目の前 広がる現実世界がまた歪んだ

何度リセットしても

僕は僕以外の誰かには生まれ変われない

「そんなの知ってるよ」

気になるあの子の噂話も

シニカル標的は次の速報

麻痺しちゃってるこっからエスケープ

麻痺しちゃってるこっからエスケープ

遠く遠くまで行けるよ

安定なんてない 不安定な世界

安定なんてない 不安定な世界

安定なんてない きっと明日には忘れるよ

fade away...do over again...

fade away...do over again...

そうだ世界はどこかがいつも嘘くさい

そうだ世界はどこかがいつも嘘くさい

綺麗事だけじゃ大事な人たちすら守れない

くだらない 僕らみんなどこか狂ってるみたい

本当のことなんか全部神様も知らない

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

僕は気にしない 君は気付かない

何処にももういないいない

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

忘れていく 忘れられていく

We don't know,We don't know.