Android日记之2012/02/15——随机不重复数

今天在检查代码的时候,发现了一个关于含有不重复随机数的使用的陷阱。一开始在看代码的时候,并没有发现这个问题,但是Debug 的时候,就发现错了。其实,就是一个很浅显的问题,主要还是写给刚进入程序员这行的朋友。

先把问题重现下,我们需要对0到15 的数字中取随机数,通过这个随机数,来保证在ValueList(为了和后面的ArrayList区分)中取到的值不重复。我并不清楚最早的做法是怎么写的,反正说是太损耗资源,就改用把ValueList中对应位置的值remove掉。觉得这样就能保证取到的值不重复了。

对吗?错。为什么?因为,列表中的值remove掉了以后,并不是说当前的位置就空出来了,就比如说,一个列表中的位置是0、1、2、3,当我把2位置的值remove了以后,只是把3位置的值前移一格,对应的值还是0、1、2,不会变成0、1、3的。

那对于这种取不重复随机数怎么做呢?

我来说个我自己的做法。首先,创建一个ArrayList来存放随机数。当我从0到15的数字中取随机数的时候,我就把这个数字和ArrayList中存在的值比对一下,如果有则接着取下一个随机数,如果没有,就添加到ArrayList中。当我ArrayList的大小为15 的时候,我就不需要再添加值了,现在肯定是有0到15之间的15个不同额随机数了。那我再按照顺序从ArrayList中取这15个数出来,作为ValueList中值的对应位置在ValueList中取值。

其实,这种随机数不重复还是有应用场合的。比如说,从一个题库中取出一批题目出来,那如何保证每次生成的题目的顺序不一样,同时,在一次做题序列中,保证题目是不重复的,就可以用到这种随机数不重复的List。

当然,这只是我个人的做法,我也相信能有人比我用更有效的方法来实现这种随机数不重复(因为要比对前面存在的数字,所以要做循环,如果取的随机数比较多的话,我这种方法的效率比较低),大家不妨交流下。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值