当前位置: 首页 > news >正文

Heap sorting

堆排序比较特殊,采用数组表示堆。

先将数组表示成大根堆或者小根堆。然后从堆中依次取根,最后形成有序序列。

#include<bits/stdc++.h>
using namespace std;const int N = 1e5 + 10;
int a[N];void bigheap(int* a, int start, int len)
{if(start < 0 || len == 1) return;int son = start * 2 + 1;int parent = start;while(son <= len){if((son+1 <= len) && (a[son] < a[son+1])){son = son+1;}if(a[parent] > a[son]){break;}int tmp = a[son];a[son] = a[parent];a[parent] = tmp;parent = son;son = parent * 2 + 1;}
}
void heapsort(int* a, int len)
{for(int i = len/2-1; i>=0; i--){bigheap(a, i, len-1);}for(int i = len - 1; i > 0; i--){int tmp = a[i];a[i] = a[0];a[0] = tmp;bigheap(a, 0, i-1);}}
int main() {int n;cin >> n;for (int i = 0; i < n; ++i) {cin >> a[i];}heapsort(a, n);for (int i = 0; i < n; ++i) {cout << a[i] << ' ';}
}

http://www.lryc.cn/news/306467.html

相关文章:

  • 开源模型应用落地-qwen2模型小试-入门篇(六)
  • c#程序,oracle使用Devart驱动解决第第三方库是us7ascii,数据乱码的问题
  • 代码随想录算法训练营第四一天 | 背包问题
  • AIDL的工作原理与使用示例 跨进程通信 远程方法调用RPC
  • K8S部署Java项目 pod报错 logs日志内容:no main manifest attribute, in app.jar
  • SQL实现模糊查询的四种方法总结
  • 爬虫基本库的使用(urllib库的详细解析)
  • 【PyQt5桌面应用开发】3.Qt Designer快速入门(控件详解)
  • react useMemo 用法
  • python学习笔记 - 标准库函数
  • 校招失败后,在小公司熬了 2 年终于进了字节跳动,竭尽全力....
  • PYTHON-使用正则表达式进行模式匹配
  • Fiddler工具 — 19.Fiddler抓包HTTPS请求(二)
  • 架构设计:流式处理与实时计算
  • Linux系统安装zookeeper
  • 【前端素材】推荐优质后台管理系统Modernize平台模板(附源码)
  • 二、Vue组件化编程
  • JVM跨代引用垃圾回收
  • AI:135-基于卷积神经网络的艺术品瑕疵检测与修复
  • C++标准头文件汇总及功能说明
  • glTF 添加数据属性(extras)
  • linux系统消息中间件rabbitmq普通集群的部署
  • TextCNN:文本分类卷积神经网络
  • 欧几里得和《几何原本》
  • linux c++ 开发 tensorrt 安装
  • Redis高并发分布锁实战
  • Kotlin基础——DSL
  • 《Docker 简易速速上手小册》第4章 Docker 容器管理(2024 最新版)
  • 【人脸朝向识别与分类预测】基于PNN神经网络
  • 【Python笔记-设计模式】组合模式