论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
应用中心
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
qidao123.com技术社区-IT企服评测·应用市场
»
论坛
›
软件与程序人生
›
后端开发
›
Java
›
基数排序
基数排序
老婆出轨
论坛元老
|
2023-7-6 18:14:22
|
显示全部楼层
|
阅读模式
楼主
主题
1992
|
帖子
1992
|
积分
5976
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
前言
基数排序是一种非常快且好写的排序。
以前一直以为基数排序就是桶排,现在发现自己很智慧,警钟长鸣。
思想
基数排序是一个以桶排为基础的排序。
桶排我就不多说了,简单且 \(O(n)\)。
但是桶排有一个弊端,就是由于考试时空间限制是 \(10^8\) 左右,可需要排序的数据是 \(10^9\) 的,就不能用桶排了。
桶排中的空间其实有一大半都是浪费了的,那么换一种思路,我们可不可以将需要排序的 \(a_i\) 拆成一位一位的再做。
这里定义 \(x_i\) 和 \(y_i\) 中,\(x_i\) 表示 \(a_i\) 的第 \(K\) 位的数,\(y_i\) 就表示第 \(K-1\) 位的数字。
然后分别对 \(x_i\) 和 \(y_i\) 进行桶排,并对 \(x_i\) 的桶 \(c_i\) 做前缀和,这时 \(x_i\) 的排名就是 \(c_{x_i-1}+1 \sim c_{x_i}\)。
再对 \(y_i\) 建立下标映射,设 \(p_{y_i}\) 为 \(y_i\) 的下标。
这里 \(x_i\) 和 \(y_i\) 因为下标相同,表示的就是 \(a_i\)。
那么我们就可以用 \(x_{p_i}\) 来表示 \(y_i\) 所对应的 \(x_i\)。
注意,这里我们
从大到小
对 \(i\) 进行遍历,\(y_i\) 就是从大到小的,其 \(a_{p_i}\) 就是 \(c_{x_{p_i}-1}+1 \sim c_{x_{p_i}}\) 范围中排名最大的。
即 \(c_{x_{p_i}}\) 就是 \(a_{p_i}\) 的排名。最后将 \(c_{x_{p_i}}\) 减一再进行下一次遍历。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
老婆出轨
论坛元老
这个人很懒什么都没写!
楼主热帖
1000套安卓(Android)毕业设计(带论 ...
【Linux学习】网络基础 和 SOCKET套接 ...
在工作中离屏真的不重要吗,代码优化就 ...
设计模式必知必会系列终章
牛客SQL刷题第三趴——SQL大厂面试真题 ...
记一次线上问题 → Deadlock 的分析与 ...
Git + Jenkins 自动化 NGINX 发布简易 ...
MySQL完整版详解
亚马逊云科技Build On-Amazon Neptune ...
SRC基础抓包
标签云
渠道
国产数据库
集成商
AI
运维
CIO
存储
服务器
快速回复
返回顶部
返回列表