我有这样的需求:
我有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));
}