这个东西是我在做一个项目的时候要用到的,想一下在大一的时候C语言练习题也有这样的一道题,但是是4个数据。当时使用的方法现在想一下简直是愚蠢的。
下面我给我最新使用的方法:
用给的数据重新随机生成一遍,可以使用循环判断的方式,这种方式也是我大一使用的,这用方法也能做,但是效率低下,并且很复杂,不容易理解。
我最近使用的方法是利用下标,当随机生成这个下标以后,把当前数据保存,移除这个数据(至于怎么移除,就要看你自己的方法了),然后再次循环。
代码如下:
package com.junl.scott.random;
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
/**
* @author scott
* @E-mail: lhdscott@163.com
* @version 1.0
* @Date and Time:2014-11-5 下午03:19:58
* @class explain 从给定的数据中,随机生成所有数据,并且对于同一个数据不同出现两次,或者两次以上。
*
* 数字个数
*
* 存放数据的Stack
*
*/
public class RandomNum
{
private int number = 9;
private Stack<Integer> stack;
public int getNumber()
{
return number;
}
public void setNumber(int number)
{
this.number = number;
}
public Stack<Integer> getStack()
{
return stack;
}
public void setStack(Stack<Integer> stack)
{
this.stack = stack;
}
public static void main(String[] args)
{
// 初始化数据
RandomNum randomNum = new RandomNum();
Stack<Integer> stack = new Stack<Integer>();
randomNum.setStack(stack);
for (int i = 1; i <= randomNum.getNumber(); i++)
{
randomNum.getStack().push(i);
}
// 获取结果集
List<Integer> numList = new ArrayList<Integer>();
/*
* 循环生成数据,我使用的方法是生成Stack下标,当这个下标使用过后,移除这个下标的数据
*
* 这样就不会出现重复生成的情况了
*/
for (int i = 0; i < randomNum.getNumber(); i++)
{
// 根据当前的Stack的size生成下标随机值
int num = (int) (Math.random() * randomNum.getStack().size());
// 添加数据
numList.add(randomNum.getStack().get(num));
// 移除下标数据
randomNum.getStack().remove(num);
}
for (Integer num : numList)
{
System.out.println(num);
}
}
}