java 线性表排序_Java线性表的排序

Java线性表的排序

前言:刚才在弄JDBC的时候,忽然觉得order-by用太多了没新鲜感,我的第六感告诉我java有对线性表排序的封装,然后在eclipse里随便按了一下“.” ,哈哈,竟然真有这么一个静态方法public static void sort(List list, Comparator super T> c)。

修改记录:根据@mythabc的的建议,添加了另一种方式。

方式一:Comparator比较器

好处:这种方式运行的时候比较灵活,如果要更换排序规则,不更改原有的比较器,而直接新建另一个比较器,在客户端换一下比较器的新类名就行了,这样比较贴近开闭原则,当累积了多个比较器后,各种排序规则可以随意转换,挺爽的;模型与排序分离,比较贴近单一职责原则。

1.先定义一个模型:

packagemodel;

public classUser

{privateString userName;private intuserAge;publicUser()

{

}public User(String userName, intuserAge)

{this.userName =userName;this.userAge =userAge;

}publicString getUserName()

{returnuserName;

}public voidsetUserName(String userName)

{this.userName =userName;

}public intgetUserAge()

{returnuserAge;

}public void setUserAge(intuserAge)

{this.userAge =userAge;

}

}

2.然后定义一个比较器,实现java.util.Comparator接口,在compare()方法编写比较规则:

packageutil;importjava.util.Comparator;importmodel.User;

public class ComparatorUser implements Comparator{

@Overridepublic intcompare(User arg0, User arg1)

{//先比较名字

int flag =arg0.getUserName().compareTo(arg1.getUserName());//如果名字一样,就比较年龄

if (flag == 0)

{return arg0.getUserAge() -arg1.getUserAge();

}returnflag;

}

}

3.排序的时候用java.util.Collections里面的sort(List list, Comparator c)方法:

packagetest;importjava.util.ArrayList;importjava.util.Collections;importjava.util.List;importutil.ComparatorUser;importmodel.User;

public classTestApp

{public static voidmain(String[] arg0)

{

List userList = new ArrayList();//插入数据

userList.add(new User("A", 15));

userList.add(new User("B", 14));

userList.add(new User("A", 14));//排序

Collections.sort(userList, newComparatorUser());//打印结果

for(User u : userList)

{

System.out.println(u.getUserName()+ " " +u.getUserAge());

}

}

}

4.运行结果:

A 14A15B14

方式二:实现Comparable接口

好处:直接让模型附带可排序的属性,不用去定义新的类(不用定义比较器),减少了类的数量,方便管理,阅读的时候比较轻松。

1.先定义一个模型,并实现Comparable接口,在compareTo()方法编写比较规则:

packagemodel;

public class Student implements Comparable{privateString studentName;private intstudentAge;publicStudent()

{

}public Student(String studentName, intstudentAge)

{this.studentName =studentName;this.studentAge =studentAge;

}publicString getStudentName()

{returnstudentName;

}public voidsetStudentName(String studentName)

{this.studentName =studentName;

}public intgetStudentAge()

{returnstudentAge;

}public void setStudentAge(intstudentAge)

{this.studentAge =studentAge;

}

@Overridepublic intcompareTo(Student o)

{//先比较名字

int flag = this.getStudentName().compareTo(o.getStudentName());//如果名字一样,就比较年龄

if (flag == 0)

{return this.getStudentAge() -o.getStudentAge();

}returnflag;

}

}

2.排序的时候用java.util.Collections里面的sort(List list)方法:

packagetest;importjava.util.ArrayList;importjava.util.Collections;importjava.util.List;importmodel.Student;

public classTestApp2

{public static voidmain(String[] arg0)

{

List studentList = new ArrayList();//插入数据

studentList.add(new Student("A", 15));

studentList.add(new Student("B", 14));

studentList.add(new Student("A", 14));//排序

Collections.sort(studentList);//打印结果

for(Student s : studentList)

{

System.out.println(s.getStudentName()+ " " +s.getStudentAge());

}

}

}

3.运行结果:

A 14A15B14

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
队列(Queue)是一种先进先出(First-In, First-Out, FIFO)的数据结构。在队列中,只允许在一端进行插入操作,而在另一端进行删除操作。添加元素的操作称为入队(enqueue),删除元素的操作称为出队(dequeue)。 栈(Stack)是一种后进先出(Last-In, First-Out, LIFO)的数据结构。在栈中,只允许在一端进行插入和删除操作。添加元素的操作称为入栈(push),删除元素的操作称为出栈(pop)。 链(Linked List)是一种非连续的、非顺序的数据结构。链中的数据元素通过链来进行连接。各个元素(节点)包含了存储数据的内容以及指向下一个元素的指针。链可以分为单向链和双向链两种类型。 线性(List)是数据元素按照一定顺序排列的数据结构。线性中的元素可以是相同类型的,也可以是不同类型的。线性的特性包括元素的有序性、位置的固定性以及元素的可重复性。线性可以通过数组或链来实现。 排序(Sorting)是对一组数据元素进行按照一定规则重新排列的操作。排序的目的是为了使数据具备一定的有序性。常见的排序算法包括冒泡排序、插入排序、选择排序、快速排序、归并排序等。排序算法的选择取决于数据量的大小、排序的稳定性要求以及时间和空间复杂度的限制。 总结起来,队列和栈是两种基本的数据结构,链线性是数据元素排列的方式,排序是一种对元素进行排列的操作。理解这些知识点可以帮助我们更好地理解和应用Java的数据结构和算法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值