bitmap(2)

 

位图应用

1. 老鼠测药:瓶子序号记为二进制格式,如果第i位为1,则第i个老鼠喝药,譬如14 = 10110,即1,2,4号老鼠喝第14号瓶,那么如果这瓶水有毒,则1、2、4号老鼠都会死亡,反推,如果1、2、4号老鼠死亡,那么三只老鼠都喝到了那一瓶毒药,所以必定是14,而非15 = 10111,如果是15,那么第0号老鼠也会死亡。

2. 随机数生成:给定能随机生成整数1到5的函数,写出能随机生成整数1到7的函数。根据r(5),生成两位的5进制数:X = X1X0,那么这个5进制随机数X范围是[0, 24],再将这个5进制数等分为7份,分别为[0,2], [3,5], [6,8], ... [18, 20],然后根据生成数确定落入的区域,得到随机数[1, 7]。

3. 数组排序:对于大规模数据,但数据范围有限且无重复的时候,可以利用位图表示来排序。对于[0, 2^n-1]范围内的数据,可以使用n位存储空间来表示每个数据,最后就可以根据位图表示按序输出数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值