我有这样的需求:
我有100道试题,id是0到99,我想从中找出20道试题组成一个试卷,要求试题不重复,打乱顺序:
/**
* 产生无重复的随机数 sumInt:总样本 (0....sumInt-1)
* resultSum: 产生的随机数个数
*
* @return
*/
public static int[] randoms(int sumInt, int resultSum) {
Random r = new Random();
int temp1, temp2;
//Total sample
int send[] = new int[sumInt];//0....(sumInt-1)
for (int i = 0; i < sumInt; i++) {
send[i] = i;
}
int len = send.length;//The length of the total sample
int returnValue[] = new int[resultSum];//Random number to return
for (int i = 0; i < resultSum; i++) {
temp1 = Math.abs(r.nextInt()) % len;
temp2 = send[temp1];
returnValue[i] = temp2;
if (temp1 != len - 1) {
send[temp1] = send[len - 1];
send[len - 1] = temp2;
}
len--;
}
return returnValue;
}
测试:
public static void printArray(int[] ints) {
for (int i = 0; i < ints.length; i++) {
System.out.print(ints[i]);
if (i < ints.length - 1) {
System.out.print(" ,");
}
}
System.out.println();
}
@Test
public void test_randoms(){
printArray(SystemUtil.randoms(5, 3));
}