将1-1000个随机数不重复的放到长度为n的数组中,要考虑哪些问题?

这是一道Java面试题,认证知道该怎么回答?将1-1000个随机数不重复的放到长度为n的数组中,要考虑哪些问题?... 这是一道Java面试题,认证知道该怎么回答?
将1-1000个随机数不重复的放到长度为n的数组中,要考虑哪些问题?
展开
 我来答
zhao372993897
2012-02-25 · TA获得超过565个赞
知道小有建树答主
回答量:267
采纳率:0%
帮助的人:174万
展开全部
实现的方法很多,所有要考虑的问题是效率问题!
最容易想到的方法,是逐个产生这些随机数,每产生一个,都跟前面的随机
数比较,如果重复,就重新产生。这是个很笨的方法,且比较次数呈线性增长,越往后次数越多
你考虑先从1-1000中随机选取n个数,在随机放入的数组,效果是一样,当减少了比较的环节,效率高很多
追问
那从1-1000中随机选取n个数,这个该怎么做呢?
追答
把1-1000放入集合,随机生成下标取值并删除,删除是保证下次取值不重复
没有响应m2
2012-02-25 · TA获得超过8387个赞
知道大有可为答主
回答量:7579
采纳率:33%
帮助的人:3513万
展开全部
用 TreeSet
TreeSet里不能有重复的元素.......
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式