小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Java筆試題:將集合中的學(xué)生信息按照學(xué)生的年齡升序排列

 流曲頻陽 2017-01-23

最近很多學(xué)員在參加筆試時都被問到集合中排序的問題,在新年的第一篇文章中給大家分享一下相關(guān)內(nèi)容?!皩⒓现械膶W(xué)生信息按照學(xué)生的年齡升序排列”這個題目主要考察的是求職者對集合中元素存取以及元素值比較的方法、排序方法(一般使用冒泡排序)、泛型集合、集合中自帶的sort方法、集合中比較器的應(yīng)用等。下面分別使用冒泡排序和Sort完成題目的要求。

無論使用哪種方法都需要先創(chuàng)建學(xué)生信息類,通常會要求在類中存放學(xué)號、年齡、姓名等屬性。學(xué)生信息類的代碼如下所示。

  1. class Student {  
  2.     private int id; 
  3.     private String name
  4.     private int age;         
  5.     public Student(int id, String nameint age) {       
  6.         this.id = id; 
  7.         this.name = name
  8.         this.age = age; 
  9.     } 
  10.     public int getId() { 
  11.         return id; 
  12.     } 
  13.     public void setId(int id) { 
  14.         this.id = id; 
  15.     } 
  16.     public String getName() { 
  17.         return name
  18.     } 
  19.     public void setName(String name) { 
  20.         this.name = name
  21.     } 
  22.     public int getAge() { 
  23.         return age; 
  24.     } 
  25.     public void setAge(int age) { 
  26.         this.age = age; 
  27.     } 
  28.     @Override 
  29.     public String toString() { 
  30.         return "Student [id=" + id + ", name=" + name + ", age=" + age + "]"
  31.     } 
  32. }     

(1)使用冒泡排序算法

由于題目要求是按照學(xué)生的年齡排序,因此,在遍歷集合元素時要根據(jù)年齡進(jìn)行比較,并交換集合中相應(yīng)元素的值。實(shí)現(xiàn)的代碼如下所示。

  1. public class TestStudent { 
  2.  
  3.     public static void main(String[] args) { 
  4.         // TODO Auto-generated method stub 
  5.         List<Student> list = new ArrayList<Student>(); 
  6.         list.add(new Student(1,"小張",20)); 
  7.         list.add(new Student(2,"小王",18)); 
  8.         list.add(new Student(3,"小李",19)); 
  9.         //使用冒泡排序算法 
  10.         for(int i=0;i<list.size()-1;i++){ 
  11.             for(int j=0;j<list.size()-1-i;j++){ 
  12.                 if(list.get(j).getAge()>list.get(j+1).getAge()){ 
  13.                     Student student=list.get(j); 
  14.                     list.set(j, list.get(j+1)); 
  15.                     list.set(j+1, student); 
  16.                 } 
  17.             } 
  18.         }        
  19.         for(Student stu:list){ 
  20.             System.out.println(stu); 
  21.         } 
  22.     } 

執(zhí)行上面的代碼,效果如圖1所示。

圖1 排序后的結(jié)果

圖1 排序后的結(jié)果

(2)使用比較器實(shí)現(xiàn)

在List集合中提供了sort方法能直接對集合中的元素實(shí)現(xiàn)冒泡排序,但由于在集合中存放的值是類的實(shí)例,而不是單純的值,因此,需要借助集合中的比較器來實(shí)現(xiàn)對學(xué)生信息類的年齡排序。使用比較器可以通過實(shí)現(xiàn)Comparator接口或者實(shí)現(xiàn)Comparable接口來完成,實(shí)現(xiàn)Comparator接口時,通常是自定義一個類來完成,并重寫compare方法;實(shí)現(xiàn)Comparable接口時,通常是直接用到要比較的類中,并重寫compareTo方法,比如,要比較學(xué)生信息類中的年齡屬性值,直接在學(xué)生信息類中實(shí)現(xiàn)Comparable接口即可。

在本例中采用的方式是實(shí)現(xiàn)Comparator接口的方式,自定義一個名為MyCompare的類,代碼如下所示。

  1. public class TestStudent { 
  2.     public static void main(String[] args) { 
  3.         // TODO Auto-generated method stub 
  4.         List<Student> list = new ArrayList<Student>(); 
  5.         list.add(new Student(1,"小張",20)); 
  6.         list.add(new Student(2,"小王",18)); 
  7.         list.add(new Student(3,"小李",19));        
  8.         Collections.sort(list,new MyCompare());  //使用比較器 
  9.         for(Student stu:list){ 
  10.             System.out.println(stu); 
  11.         } 
  12.     } 

執(zhí)行上面的代碼,效果與圖1一致。

至此,使用了2種方式完成將集合中學(xué)生信息按照年齡升序排序的操作。當(dāng)然,完成對集合中元素排序的操作會有很多方法,這里只是給出2種參考方法,希望會對大家有所幫助和啟示。

【編輯推薦】

【責(zé)任編輯:武曉燕 TEL:(010)68476606】

點(diǎn)贊 0

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多