新手請問這個程序哪里出錯,跪求大神解答?。。。?!
/**
* 3.對其他類型泛型的List進(jìn)行排序,以Student為例。
* 其中生成的id為1000以內(nèi)不重復(fù)的整數(shù)
*/
public void testStudentSort() {
Random r= new Random();
for(int i=0;i<3;i++ ) {
int id=r.nextInt(1000);
String name =dllx.next();
System.out.println("請輸入第"+(i+1)+"個學(xué)生的姓名:");
do{
student.add(new Student(id+"",name));
}while (student.contains(id));
}
System.out.println("--------------排序前------------");
for (Student student2 : student) {
System.out.println(student2.getId()+":"+student2.getName());
}
Collections.sort(student);
System.out.println("--------------排序后------------");
for (Student student2 : student) {
System.out.println(student2.getId()+":"+student2.getName());
}
}
2018-08-30
正確思路是:do的時候隨機(jī)一個ID,while的時候判斷是否包含這個ID,然后花括號中添加這個ID
這樣就形成了一個ID的隨機(jī)添加,for循環(huán)3次。
在一開始如果需要有一個循環(huán)有固定的多個結(jié)果,優(yōu)先使用for
for3次循環(huán),用if判斷contains,然后添加。
這樣思路就不會亂,并且在需要擴(kuò)展的時候也很方便
當(dāng)然dowhile更符合你的胃口的話,也挺好
我在實現(xiàn)的時候其實為了讓思路更加清晰,使用了三個while進(jìn)行判斷三個隨機(jī)數(shù)互不相等,然后直接使用三個while當(dāng)中的參數(shù)引用到new Student的ID當(dāng)中去,這樣雖然看起來笨重,但是對于原始的代碼影響最小,但是也不符合后期的修改和擴(kuò)容。希望能給你帶來靈感
2018-08-24
你的邏輯是當(dāng)list中存在當(dāng)前id時,會一直添加這個student
2018-06-01
System.out.println("請輸入第"+(i+1)+"個學(xué)生的姓名:");這句不應(yīng)該寫在前面嗎?