java 线性表排序,java线性表排序示例分享

大家可以先看一下这个静态方法public static void sort(List list, Comparator super T> c)

1.先定义一个模型:

复制代码 代码如下:

package model;

/**

* User.java

*

* @author 梁WP 2014年3月3日

*/

public class User

{

private String userName;

private int userAge;

public User()

{

}

public User(String userName, int userAge)

{

this.userName = userName;

this.userAge = userAge;

}

public String getUserName()

{

return userName;

}

public void setUserName(String userName)

{

this.userName = userName;

}

public int getUserAge()

{

return userAge;

}

public void setUserAge(int userAge)

{

this.userAge = userAge;

}

}

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

复制代码 代码如下:

package util;

import java.util.Comparator;

import model.User;

/**

* ComparatorUser.java

*

* @author 梁WP 2014年3月3日

*/

public class ComparatorUser implements Comparator

{

@Override

public int compare(User arg0, User arg1)

{

// 先比较名字

int flag = arg0.getUserName().compareTo(arg1.getUserName());

// 如果名字一样,就比较年龄

if (flag == 0)

{

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

}

return flag;

}

}

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

复制代码 代码如下:

package test;

import java.util.ArrayList;

import java.util.Collections;

import java.util.List;

import util.ComparatorUser;

import model.User;

/**

* TestApp.java

*

* @author 梁炜平 2014年3月3日

*/

public class TestApp

{

public static void main(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, new ComparatorUser());

// 打印结果

for (User u : userList)

{

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

}

}

}

4.运行结果:

复制代码 代码如下:

A 14

A 15

B 14

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值