五大排序
做到了相关的题,所以来总结一下
以复杂度排序
一、计数排序(n+k)
原理
记录每个数出现次数,依次枚举数的大小
限制
1、输入的数据类型需是区间内有限的,浮点数就不行
2、数的大小在有限范围内
稳定
代码
#include<bits/stdc++.h> using namespace std; int main(){ n=read(); for(int i=1;i<=n;++i) a[read()]++; for(int i=0;i<=k;++i) while(a[i]--) cout<<i<<" "; }
二、堆排序(nlogn)
原理
利用优先队列内部排序,直接输入输出
限制
只能挨个取数,并且是一次性取
不稳定
代码
#include <iostream> #include <queue> using namespace std; priority_queue<int,vector<int>,greater<int> > a; //定义小根堆(小顶堆),从小到大排序 int n,t; int main() { n=read(); for (int i=1;i<=n;i++) a.push(read()); for (int i=1;i<=n;i++) cout <<a.top() <<' ',a.pop(); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律