问答详情
源自:6-8 学生选课--- 实现学生序列排序

三个不重复的整数还有更简洁的方法嘛?

// 三个不重复的整数
        while (i == j)
        {
            j = random.nextInt(1000);
        }
        while (i == k || k == j)
        {
            k = random.nextInt(1000);
        }

        studentList.add(new Student(i + "", "Mike"));
        studentList.add(new Student(j + "", "Angela"));
        studentList.add(new Student(k + "", "Lucy"));
       



我感觉这个实现太长了,谁有更简洁的方法来实现

提问者:songqi12so 2018-08-30 12:03

个回答

  • 慕码人8582911
    2019-10-19 12:26:38

    如图,加油http://img.mukewang.com/5daa90790001cce508500438.jpg

  • zooeaa
    2019-05-24 08:57:19

    	/**
    	* 3.对其他类型泛型的List进行排序,以Student为例。
    	*/
    	public void testSort3() {
    	    List<Student> studentList = new ArrayList<Student>();
    	    Random random = new Random();
    	    
    	    int f = random.nextInt(1000);
    	    studentList.add(new Student(f + "", "Mike"));
    	    
    	    do
    	        f = random.nextInt(1000);
    	    while (studentList.contains(f));
    	    studentList.add(new Student(f + "", "Zom"));
    	    
    	    do
    	        f = random.nextInt(1000);
    	    while (studentList.contains(f));
    	    studentList.add(new Student(f + "", "Jason"));
    	    
    	    System.out.println("---------HOME----------");
    	    for (Student student : studentList) {
    	        System.out.println("学生:" + student.getId() + "," + student.getName());
    	    }
    	    
    	    System.out.println("---------END----------");
    	    Collections.sort(studentList);
    	    for (Student student : studentList) {
    	        System.out.println("学生:" + student.getId() + "," + student.getName());
    	    }
    	}
    	
    	不知道我这个算不算简单,
    	使用了ArrayList的contains方法判断元素是否重复,
    	元素重复返回true。


  • 墨锦
    2019-02-19 20:48:16

          public void testSort3(){

       List<Integer> integerList = new ArrayList<Integer>();

         List<Student> studentList = new ArrayList<Student>();

         Random random=new Random();

         Integer k;

            for(int i=0;i<3;i++){

           do{ k=random.nextInt(100);

         

         }while(integerList.contains(k));

        integerList.add(k);

          }

            

         studentList.add(new Student(integerList.get(0)+"","Mike"));

         studentList.add(new Student(integerList.get(1)+"","Angela"));

         studentList.add(new Student(integerList.get(2)+"","Lucy"));

       脑子笨,把testSort1合并进来用了

  • 五岁麻瓜少年
    2018-11-26 17:13:32

    int i;
    int j;
    int k;
    do {
         i = random.nextInt(10);
         j = random.nextInt(10);
         k = random.nextInt(10);
    }while (i==j||i==k||j==k);

    不知道我的这个是不是简单易懂呢

  • 慕沐4503986
    2018-10-16 13:21:39

    public void test(){
    Set<Integer>set=new HashSet<Integer>();
    Random random=new Random();
    while(set.size()<3){
    int i=random.nextInt(1000);
    set.add(i);
    }
    这个就是利用set的不重复性来创建三个不重复的整数。
    但是我不知道该怎么样才能将数字带入替换student的ID属性


  • 慕粉7269117
    2018-09-21 17:51:22

    或许可以利用hashSet不可重复的特性

  • 慕哥3549570
    2018-09-15 16:45:10

    while(set1.size()<3){

    set1.add(random.nextInt(1000));

    }

  • songqi12so
    2018-08-30 12:24:31

    当然最好是不影响原来的代码的情况下。