定义一个随机数类

    1. // 从 m个整数中随机抽取 n个整数,条件: m > n
    2. public static int[] genRandomArray(int m , int n) {
    3. if(m<=0) return null;
    4. if(n<=0) return null;
    5. if(m< n) return null;
    6. int[] intRet = new int[n];
    7. int intRd = 0; // 存放随机数
    8. int count = 0; // 记录生成的随机数个数
    9. boolean flag = false; // 是否已经生成过标志
    10. while(count< n){
    11. Random rdm = new Random(System.currentTimeMillis());
    12. intRd = Math.abs(rdm.nextInt())%m +1;
    13. for(int i=0;i<count;i++){
    14. if(intRet[i]==intRd){
    15. flag = true;
    16. break;
    17. }else{
    18. flag = false;
    19. }
    20. }
    21. if(flag==false){
    22. intRet[count] = intRd;
    23. count++;
    24. }
    25. }
    26. return intRet;
    27. }

    每个类中的main方法

    1. public static void main(String[] args) {
    2. //获取当前系统运行时间戳
    3. long l0 = System.currentTimeMillis();
    4. int[] ints = random.genRandomArray(1000, 900);
    5. for (int i : ints) {
    6. System.out.println(i);
    7. }
    8. System.out.println("****************************************");
    9. long l1 = System.currentTimeMillis();
    10. sort(ints);
    11. long l2 = System.currentTimeMillis();
    12. for (int anInt : ints) {
    13. System.out.println(anInt);
    14. }
    15. System.out.println(l1-l0+"ms");
    16. System.out.println(l2-l1+"ms");
    17. }

    可以知道每个排序的运行时间