免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3889 | 回复: 4
打印 上一主题 下一主题

关于Random,想从1--100之间随机不重复的20个数,赋给a[ ]数组,如何实现? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-01-28 12:06 |只看该作者 |倒序浏览
问题描述:

想从1--100之间随机不重复的20个数,赋给a[ ]数组,如何实现?


Random是否有直接实现的函数?


还是要通过这样的思路解决:随机1个数,然后与现有的a[ ]逐个比较,如未有重复则放入a[ ],如重复则再随机——如此循环···

如果要这样的话,不是多出不少开销吗?

论坛徽章:
0
2 [报告]
发表于 2009-02-02 17:30 |只看该作者
把随机出来的数放到set集合里,可不可以 Set<Integer>

论坛徽章:
0
3 [报告]
发表于 2009-02-02 18:51 |只看该作者
能详细点吗?

论坛徽章:
0
4 [报告]
发表于 2009-02-03 11:21 |只看该作者
瞎写了一个,仅供参考


  1. public Integer[] getArray() {
  2.                 Random random = new Random();
  3.                 List<Integer> list = new ArrayList<Integer>();
  4.                 int k;
  5.                 while (list.size() != 20) {
  6.                         k = random.nextInt(100);
  7.                         if(k==0)
  8.                                 continue;
  9.                         if (!list.contains(new Integer(k))) {
  10.                                 list.add(k);
  11.                         }
  12.                 }

  13.                 return list.toArray(new Integer[20]);
  14.         }

复制代码

论坛徽章:
0
5 [报告]
发表于 2009-02-03 23:04 |只看该作者

回复 #1 狼神萧枫 的帖子

用java自带的set实现 比自己实现的效率要高好多啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP