码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【排序】桶排序(c++)


    今天,我们来讲一种非常高效的排序方法——桶排序!


    桶排序的原理

    想象一下,我们现在有这样一串数字:1、2、3、4、1、2、3、4、1、2、3、4

    我们应该怎么样排序呢?

    我们观察一下,首先,这一串数据有很多重复的数字(1~4都出现了3次),那这个特点有什么用呢?别急,我们来排序一下:

    1、2、3、4、1、2、3、4

    第1个木桶:1

    第2个木桶:2

    第3个木桶:3

    第4个木桶:4

    (将数列最开始的4个数扔进木桶里)

    1、2、3、4

    第1个木桶:1、1

    第2个木桶:2、2

    第3个木桶:3、3

    第4个木桶:4、4

    (数列空了)

    第1个木桶:1、1、1

    第2个木桶:2、2、2

    第3个木桶:3、3、3

    第4个木桶:4、4、4

    那我们已经把所有的数字都装进了木桶里,现在我们要怎么输出?

    只要你不算笨的话,应该都会想到怎么输出:首先将第一个木桶里的所有数都输出,将第二个木桶里的数全部输出……

    刚刚这种排序方法就叫桶排序,总结一下,桶排序是在数列中的很多数字重复的情况下才能使用的,比如数列1、2、3、4,我们把数列遍历一遍,遇到1,把b[1]++;(b数组用于记录每个数字出现了多少次),遇到2,就把b[2]++;……

    注意了,桶排序的时间复杂度是O(n+m)(n是数列的元素个数,m是数列里最大的数字),如果数列里的数字都很小,比如最大的数字只有4,那我们就可以用桶排序,如果有很多的重复数字,我们也可以考虑桶排序


    代码:

    1. #include
    2. using namespace std;
    3. long long b[100];//b就是标记数字出现次数用的数组
    4. //我这里假设数列中最大的数为99,所以要开100个数组
    5. int main(){
    6. long long n;//几个数列元素
    7. cin>>n;//读入
    8. long long a[n+10];
    9. for(int i=1;i<=n;i++){
    10. cin>>a[i];//读入
    11. b[a[i]]++;//那a[i]这一项就可以+1了(找到一个数了)
    12. }
    13. for(int i=1;i<=100;i++){
    14. if(b[i]>0){//如果b[i]里的数字>0,说明数列里有出现i这个数字
    15. for(int j=1;j<=b[i];j++){//这样才能输出
    16. cout<" ";//有出现i,就输出i
    17. }
    18. }
    19. }
    20. return 0;
    21. }

  • 相关阅读:
    TensorFlow 2.9的零零碎碎(一)
    MaxEnt模型融合技术的物种分布模拟、参数优化方法、结果分析制图与论文写作
    TiDB 集群报警规则
    Java基础
    北京旅游HTML学生网页设计作品 dreamweaver作业静态HTML网页设计模板 北京旅游景点网页作业制作 HTML+CSS+JS
    怎么建立一个简单的程序化交易系统?
    7.MySQL复合查询
    【技术积累】HTML+CSS+JavaScript中的基础知识【三】
    深度学习——(生成模型)DDPM
    java多线程并发环境下为什么使用while而不用if
  • 原文地址:https://blog.csdn.net/ptyz306/article/details/132794449
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号