算法之美——位图排序

辉爷在高级数据结构课程中讲解了位图排序。这是一种线性的排序算法,通过设置和清除二进制位实现排序。置1操作是通过或操作,置0操作则用与操作。讲解还涉及优化和在STL中的实现,展示了位图排序的广泛应用。
摘要由CSDN通过智能技术生成

辉爷的高级数据结构开讲了,辉爷V5啊,今天辉爷讲的是位图排序

 

问题描述:

输入
给出至多10,000,000个正整数的序列
特征:
每个数都小于10,000,000
数据不重复且 数据之间不存在关联关系
输出:增序输出序列
约束:
内存容量1MB
磁盘空间充足
运行时间至多几分钟---最好线性时间

 

解答:

首先回顾下计数排序:

思想:
根据待排序中最大的数,开辟一个数组,记录每个整数出现的次数
遍历一遍待排序的数据(排序的过程)
顺序输出结果
要求
必须提前知道待排序数的最大数
缺点
有些数没有出现过,仍要为其保留一个空间
只能针对整数进行处理
优点

线性的排序算法

 

位图排序:

引入位图排序的原因
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值