`
iflytek_wjzhu
  • 浏览: 39174 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
最近访客 更多访客>>
社区版块
存档分类
最新评论

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
分享到:
评论
2 楼 iflytek_wjzhu 2012-02-28  
黯然小伙 写道
我来说个我自己的做法。首先,创建一个ArrayList来存放随机数。当我从0到15的数字中取随机数的时候,我就把这个数字和ArrayList中存在的值比对一下,如果有则接着取下一个随机数,如果没有,就添加到ArrayList中。当我ArrayList的大小为15 的时候,我就不需要再添加值了,现在肯定是有0到15之间的15个不同额随机数了。那我再按照顺序从ArrayList中取这15个数出来,作为ValueList中值的对应位置在ValueList中取值。


这样的话如果运气不好的话,岂不是要随机很多次。没必要。随机下标就好了。。
//初始化
		List<Integer> list = new ArrayList<Integer>();
		for (int i = 1; i <= 15; i++) {
			list.add(i);
		}
		//不重复随机数
		for (int i = 0; i < 100; i++) {
			//随机下标
			int index = new Random().nextInt(list.size());
			//取出
			System.out.println(list.get(index));
			//删除
			list.remove(index);
			//判断是否取完
			if(list.isEmpty()){
				break;
			}
		}

嗯,自己写了一个Demo,看了下,理解了~~~谢谢,很不错的方法~~~
1 楼 黯然小伙 2012-02-24  
我来说个我自己的做法。首先,创建一个ArrayList来存放随机数。当我从0到15的数字中取随机数的时候,我就把这个数字和ArrayList中存在的值比对一下,如果有则接着取下一个随机数,如果没有,就添加到ArrayList中。当我ArrayList的大小为15 的时候,我就不需要再添加值了,现在肯定是有0到15之间的15个不同额随机数了。那我再按照顺序从ArrayList中取这15个数出来,作为ValueList中值的对应位置在ValueList中取值。


这样的话如果运气不好的话,岂不是要随机很多次。没必要。随机下标就好了。。
//初始化
		List<Integer> list = new ArrayList<Integer>();
		for (int i = 1; i <= 15; i++) {
			list.add(i);
		}
		//不重复随机数
		for (int i = 0; i < 100; i++) {
			//随机下标
			int index = new Random().nextInt(list.size());
			//取出
			System.out.println(list.get(index));
			//删除
			list.remove(index);
			//判断是否取完
			if(list.isEmpty()){
				break;
			}
		}

相关推荐

Global site tag (gtag.js) - Google Analytics