当前位置:首页 > 系统运维

Java笔试题:将集合中的学生信息按照学生的年龄升序排列

最近很多学员在参加笔试时都被问到集合中排序的笔试问题,在新年的集合***篇文章中给大家分享一下相关内容。“将集合中的学生信息学生序排学生信息按照学生的年龄升序排列”这个题目主要考察的是求职者对集合中元素存取以及元素值比较的方法、排序方法(一般使用冒泡排序)、按照泛型集合、龄升列集合中自带的笔试sort方法、集合中比较器的集合应用等。下面分别使用冒泡排序和Sort完成题目的学生信息学生序排要求。

无论使用哪种方法都需要先创建学生信息类,按照通常会要求在类中存放学号、龄升列年龄、笔试姓名等属性。集合学生信息类的学生信息学生序排代码如下所示。

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)使用冒泡排序算法

由于题目要求是按照学生的年龄排序,因此,云服务器提供商龄升列在遍历集合元素时要根据年龄进行比较,并交换集合中相应元素的值。实现的代码如下所示。

public class TestStudent {      public static void main(String[] args) {          // TODO Auto-generated method stub         List<Student> list = new ArrayList<Student>();         list.add(new Student(1,"小张",20));         list.add(new Student(2,"小王",18));         list.add(new Student(3,"小李",19));         //使用冒泡排序算法         for(int i=0;i<list.size()-1;i++){              for(int j=0;j<list.size()-1-i;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);         }     } } 

执行上面的代码,效果如图1所示。

图1 排序后的结果

(2)使用比较器实现

在List集合中提供了sort方法能直接对集合中的元素实现冒泡排序,但由于在集合中存放的值是类的实例,而不是单纯的值,因此,需要借助集合中的比较器来实现对学生信息类的年龄排序。使用比较器可以通过实现Comparator接口或者实现Comparable接口来完成,实现Comparator接口时,通常是自定义一个类来完成,并重写compare方法;实现Comparable接口时,源码下载通常是直接用到要比较的类中,并重写compareTo方法,比如,要比较学生信息类中的年龄属性值,直接在学生信息类中实现Comparable接口即可。

在本例中采用的方式是实现Comparator接口的方式,自定义一个名为MyCompare的类,代码如下所示。

public class TestStudent {      public static void main(String[] args) {          // TODO Auto-generated method stub         List<Student> list = new ArrayList<Student>();         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);         }     } } 

执行上面的代码,效果与图1一致。

至此,使用了2种方式完成将集合中学生信息按照年龄升序排序的操作。当然,完成对集合中元素排序的操作会有很多方法,这里只是给出2种参考方法,希望会对大家有所帮助和启示。云南idc服务商

分享到:

滇ICP备2023006006号-16