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

成都創(chuàng)新互聯(lián)公司是一家專(zhuān)業(yè)從事成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)的品牌網(wǎng)絡(luò)公司。如今是成都地區(qū)具影響力的網(wǎng)站設(shè)計(jì)公司,作為專(zhuān)業(yè)的成都網(wǎng)站建設(shè)公司,成都創(chuàng)新互聯(lián)公司依托強(qiáng)大的技術(shù)實(shí)力、以及多年的網(wǎng)站運(yùn)營(yíng)經(jīng)驗(yàn),為您提供專(zhuān)業(yè)的成都網(wǎng)站建設(shè)、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)及網(wǎng)站設(shè)計(jì)開(kāi)發(fā)服務(wù)!
無(wú)論使用哪種方法都需要先創(chuàng)建學(xué)生信息類(lèi),通常會(huì)要求在類(lèi)中存放學(xué)號(hào)、年齡、姓名等屬性。學(xué)生信息類(lèi)的代碼如下所示。
- class Student {
- private int id;
- private String name;
- private int age;
- public Student(int id, String name, int age) {
- this.id = id;
- this.name = name;
- this.age = age;
- }
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- @Override
- public String toString() {
- return "Student [id=" + id + ", name=" + name + ", age=" + age + "]";
- }
- }
(1)使用冒泡排序算法
由于題目要求是按照學(xué)生的年齡排序,因此,在遍歷集合元素時(shí)要根據(jù)年齡進(jìn)行比較,并交換集合中相應(yīng)元素的值。實(shí)現(xiàn)的代碼如下所示。
- public class TestStudent {
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- List
list = new ArrayList (); - list.add(new Student(1,"小張",20));
- list.add(new Student(2,"小王",18));
- list.add(new Student(3,"小李",19));
- //使用冒泡排序算法
- for(int i=0;i
- for(int j=0;j
- if(list.get(j).getAge()>list.get(j+1).getAge()){
- Student student=list.get(j);
- list.set(j, list.get(j+1));
- list.set(j+1, student);
- }
- }
- }
- for(Student stu:list){
- System.out.println(stu);
- }
- }
- }
執(zhí)行上面的代碼,效果如圖1所示。
圖1 排序后的結(jié)果
(2)使用比較器實(shí)現(xiàn)
在List集合中提供了sort方法能直接對(duì)集合中的元素實(shí)現(xiàn)冒泡排序,但由于在集合中存放的值是類(lèi)的實(shí)例,而不是單純的值,因此,需要借助集合中的比較器來(lái)實(shí)現(xiàn)對(duì)學(xué)生信息類(lèi)的年齡排序。使用比較器可以通過(guò)實(shí)現(xiàn)Comparator接口或者實(shí)現(xiàn)Comparable接口來(lái)完成,實(shí)現(xiàn)Comparator接口時(shí),通常是自定義一個(gè)類(lèi)來(lái)完成,并重寫(xiě)compare方法;實(shí)現(xiàn)Comparable接口時(shí),通常是直接用到要比較的類(lèi)中,并重寫(xiě)compareTo方法,比如,要比較學(xué)生信息類(lèi)中的年齡屬性值,直接在學(xué)生信息類(lèi)中實(shí)現(xiàn)Comparable接口即可。
在本例中采用的方式是實(shí)現(xiàn)Comparator接口的方式,自定義一個(gè)名為MyCompare的類(lèi),代碼如下所示。
- public class TestStudent {
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- List
list = new ArrayList (); - list.add(new Student(1,"小張",20));
- list.add(new Student(2,"小王",18));
- list.add(new Student(3,"小李",19));
- Collections.sort(list,new MyCompare()); //使用比較器
- for(Student stu:list){
- System.out.println(stu);
- }
- }
- }
執(zhí)行上面的代碼,效果與圖1一致。
至此,使用了2種方式完成將集合中學(xué)生信息按照年齡升序排序的操作。當(dāng)然,完成對(duì)集合中元素排序的操作會(huì)有很多方法,這里只是給出2種參考方法,希望會(huì)對(duì)大家有所幫助和啟示。
網(wǎng)站欄目:Java筆試題:將集合中的學(xué)生信息按照學(xué)生的年齡升序排列
網(wǎng)站網(wǎng)址:http://www.dlmjj.cn/article/dpeopeo.html


咨詢(xún)
建站咨詢(xún)
