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

数据结构--堆排序

NO.1 概念

堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,时间复杂度均为O(nlogn),是不稳定排序。
堆是完全二叉树

NO.2 如何手写一个堆

1. 插入一个数  heap[++size] = x; up(size);

2. 求集合当中的最小值  heap[1];

3.删除最小值  heap[1] = heap[size];size--;down(1);

4.删除任意一个元素  heap[k] = heap[size];size--;down[k];up[k];

5.修改任意一个元素  heap[k] = x;down[k];up[k];

NO.3 例题:堆排序

(来源:838. 堆排序 - AcWing题库 )

题目:

输入一个长度为 n 的整数数列,从小到大输出前 m 小的数。

输入格式

第一行包含整数 n 和 m。

第二行包含 n 个整数,表示整数数列。

输出格式

共一行,包含 m 个整数,表示整数数列中前 m 小的数。

数据范围
1≤m≤n≤10^5,
1≤数列中元素≤10^9
输入样例:
5 3
4 5 1 3 2
输出样例:
1 2 3

代码:

#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<cmath>
#include<vector>
using namespace std;
const int N = 1e5 + 10;
int a[N],size1;
void down(int u){
	int t = u;
	if(2*u <= size1 && a[u*2] < a[t]) t = u*2;
	if(2*u+1 <= size1 && a[u*2+1] < a[t]) t = u*2+1; 
	if(u != t){
		swap(a[u],a[t]);
		down(t);
	}
}
int main(){
	int n,m;
	cin >> n >> m;
	size1 = n;
	for(int i = 1;i <= n;i ++)
		cin >> a[i];
	for(int i = n/2;i >= 0;i --)
		down(i);
	while(m --){
		printf("%d ",a[1]);
		a[1] = a[size1];
		size1 --;
		down(1);
	}
	return 0;
}


http://www.kler.cn/a/154178.html

相关文章:

  • Linux之vim模式下全选命令
  • H.265流媒体播放器EasyPlayer.js视频流媒体播放器关于直播流播放完毕是否能监听到
  • 基于Java Springboot编程语言在线学习平台
  • Halcon HImage 与 Qt QImage 的相互转换(修订版)
  • JAVA-链表
  • 无人机动力系统测试-实测数据与CFD模拟仿真数据关联对比分析
  • 【开源】基于JAVA语言的考研专业课程管理系统
  • YOLOv8界面-目标检测+语义分割+追踪+姿态识别(姿态估计)+界面DeepSort/ByteTrack-PyQt-GUI
  • 【开源】基于Vue+SpringBoot的音乐平台
  • windows配置go调用python的编译环境
  • 【开箱即用】前后端同时开源!周末和AI用Go语言共同研发了一款笔记留言小程序!
  • Web3.0时代:区块链DAPP将如何颠覆传统模式
  • 深度学习:什么是知识蒸馏(Knowledge Distillation)
  • 前端面试灵魂提问(1)
  • 深度学习 -- 神经网络
  • 【Linux】ubuntu配置SSH服务
  • 【HarmonyOS开发】ArkTs编译为SO包的流程记录
  • k8s中Service负载均衡和Service类型介绍
  • Mac苹果视频剪辑:Final Cut Pro Mac
  • 线上CPU飙高问题排查!
  • React-hook-form-mui(五):包含内嵌表单元素的表单
  • 蓝桥杯每日一题2023.12.2
  • 微服务实战系列之Cache
  • 华为OD机试真题-两个字符串间的最短路径问题-2023年OD统一考试(C卷)
  • #Css篇:实现一个元素水平和垂直居中实现左右固定,中间自身适应布局 左侧固定 右侧自适应
  • 【小布_ORACLE笔记】Part11-1--RMAN Backups