List集合中的元素进行排序
Collections对List集合中的数据进行排序
有时候需要对集合中的元素按照一定的规则进行排序,这就需要用到
Java中提供的对集合进行操作的工具类Collections,其中的sort方法
1 package com.kaishengit;
2
3 import java.util.Arrays;
4 import java.util.Collections;
5 import java.util.List;
6 /**
7 * @author Wgs
8 * @version 1.0
9 * @create:2018/04/28
10 */
11 public class SortDemo {
12 public static void main(String[] args) {
13 List<Integer> srs = Arrays.asList(5,2,9,3,4);
14 System.out.println("----排序前----");
15 // 5 2 9 3 4
16 prints(srs);
17 // 排序
18 Collections.sort(srs);
19 System.out.println("----排序后----");
20 // 2 3 4 5 9
21 prints(srs);
22 }
23
24 private static void prints(List<Integer> srs) {
25 for (Integer s : srs){
26 System.out.println(s);
27 }
28 }
29 }
结果
56,34
23,55
23,67
26,78
稍微复杂的List里面放一个复杂的对象
1 package com.kaishengit;
2
3 import java.util.ArrayList;
4 import java.util.Collections;
5 import java.util.List;
6
7 /**
8 * @author Wgs
9 * @version 1.0
10 * @create:2018/04/28
11 */
12 public class User implements Comparable<User> {
13 private int age;
14 private int score;
15
16 public User(int age, int score) {
17 this.age = age;
18 this.score = score;
19 }
20
21 public int getAge() {
22 return age;
23 }
24
25 public void setAge(int age) {
26 this.age = age;
27 }
28
29 public int getScore() {
30 return score;
31 }
32
33 public void setScore(int score) {
34 this.score = score;
35 }
36
37 @Override
38 public int compareTo(User o) {
39 // 先按照年龄排序
40 int i = this.getAge() - o.age;
41 // 年龄相等按照成绩排序
42 if (i == 0) {
43 i = this.getScore() - o.getScore();
44 }
45 return i;
46 }
47
48 public static void main(String[] args) {
49 List<User> users = new ArrayList<User>();
50 users.add(new User(78, 26));
51 users.add(new User(67, 23));
52 users.add(new User(34, 56));
53 users.add(new User(55, 23));
54 Collections.sort(users);
55 for (User user : users) {
56 System.out.println(user.getScore() + "," + user.getAge());
57 }
58
59 /**
60 * 56,34
61 * 23,55
62 * 23,67
63 * 26,78
64 */
65 }
66 }
我们会发现sort(List<T>)方法中List中的T必须实现Comparable<T>接口,然后实现compareTo()方法,该方法的返回值0代表相等,1表示大于,-1表示小于;为什么在简单例子中没有看到实现Comparable接口呢?是因为Integer类其实自己已经实现了Comparable接口,Java已经给我们做好了。
Collections提供的第二种排序方法sort(List<T> list, Comparator<? super T> c)
1 package com.kaishengit;
2
3 import java.util.ArrayList;
4 import java.util.Collections;
5 import java.util.Comparator;
6 import java.util.List;
7
8 /**
9 * @author Wgs
10 * @version 1.0
11 * @create:2018/04/28
12 */
13 public class User {
14 private int age;
15 private int score;
16
17 public User(int age, int score) {
18 this.age = age;
19 this.score = score;
20 }
21
22 public int getAge() {
23 return age;
24 }
25
26 public void setAge(int age) {
27 this.age = age;
28 }
29
30 public int getScore() {
31 return score;
32 }
33
34 public void setScore(int score) {
35 this.score = score;
36 }
37
38
39 public static void main(String[] args) {
40 List<User> users = new ArrayList<User>();
41 users.add(new User(78, 26));
42 users.add(new User(67, 23));
43 users.add(new User(34, 56));
44 users.add(new User(55, 23));
45 Collections.sort(users, new Comparator<User>() {
46 @Override
47 public int compare(User o1, User o2) {
48 int i = o1.getScore() - o2.getScore();
49 if(i == 0){
50 return o1.getAge() - o2.getAge();
51 }
52 return i;
53 }
54 });
55 for (User user : users) {
56 System.out.println(user.getScore() + "," + user.getAge());
57 }
58
59 /**
60 * 56,34
61 * 23,55
62 * 23,67
63 * 26,78
64 */
65 }
66 }
从上面的例子我们可以看出Students类没有实现Comparable<T>接口,只是在sort()方法
中多传入一个参数,只不过该参数是一个接口我们需要实现其compare方法。
List集合中的元素进行排序的更多相关文章
- java如何对List集合中的元素进行排序(请收藏)
在java开发中有时候我们需要对List集合中的元素按照一定的规则进行排序,比如说有个Person的集合,我们要根据Person的age属性进行排序输出,这就需要用到Java中提供的对集合进行操作的工 ...
- 2018.9.17 面试问题-----如何对List集合中的元素进行排序?
Collections对List集合中的数据进行排序 有时候需要对集合中的元素按照一定的规则进行排序,这就需要用到 Java中提供的对集合进行操作的工具类Collections,其中的sort方法 先 ...
- 对List集合中的元素进行排序
原文:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元素按 ...
- c#---部分;把数组或者结构体存入集合里,然后再从集合中取出之后,输出;foreach既可以用到提取数组重点额数据,也可以提取集合中的数据(前提是集合中的元素是相同数据类型)
1.输入班级人数,统计每个人的姓名,性别,年龄:集合与数组 //Console.Write("请输入班级人数:"); //int a = int.Parse(Console.Rea ...
- 对list集合中的对象进行排序(转载)
原文链接:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元 ...
- 谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。
谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数. Google2009华南地 ...
- java中对List中的元素进行排序
Collections对List集合中的数据进行排序 有时候需要对集合中的元素按照一定的规则进行排序,这就需要用到 Java中提供的对集合进行操作的工具类Collections,其中的sort方法 N ...
- 巧妙利用ToArray()函数移除集合中的元素
当我们对集合foreach遍历时,不能直接移除遍历的集合的元素,解决的方法有很多种,见我之前的随笔: http://www.cnblogs.com/527289276qq/p/4331000.html ...
- list,set等集合遍历时,不能remove集合中的元素。需要new一个Object或者list,set,里面add需要删除的元素,等集合遍历完了进行remove(Object)或者removeAll(list/set)操作
list,set等集合遍历时,不能remove集合中的元素.需要new一个Object或者list,set,里面add需要删除的元素,等集合遍历完了进行remove(Object)或者removeAl ...
- 删除 list 集合中的元素
删除 list 集合中的元素,当删除的元素有多个的时候,只能使用迭代器来删除. 当删除 list 集合中的元素只有一个的时候,有三种方法都可以实现. import java.util.ArrayLis ...
随机推荐
- 如何使用Arthas提高日常开发效率?
简介: 1. Arthas有什么功能,怎么用,请看:Arthas使用手册 2. Arthas命令比较复杂,一个帮助生成命令的IDEA插件:arthas idea plugin 使用文档 3. 基于Ar ...
- [Nova] belongsTo, belongsToMany 当前页动态 dependsOn 其它 fields, nova-belongs-to-dependency, belongs-to-many-field-nova
nova-belongs-to-dependency 例子: use Manmohanjit\BelongsToDependency\BelongsToDependency; ... return [ ...
- OSI模型之数据链路层
一.简介 数据链路层在物理层提供服务的基础上向网络层提供服务,其最基本的服务是将源自网络层的数据可靠地传输到相邻节点的目标机网络层.其主要作用是加强物理层传输原始比特流的功能,将物理层提供的可能出错的 ...
- 使用 Docker 自建一款怀旧游戏之 - 扫雷
1)扫雷 简介 扫雷 是一种经典的单人电脑游戏,最初由微软公司在 1990 年代开发并内置在 Windows 操作系统中.游戏的目标是在一个由方块组成的网格上揭开所有非地雷的方块,而不触发地雷.每个方 ...
- CF1872G
题意:一个正整数序列,\(a[i] < 10^9\),求 \(l\),\(r\),最大化 \[\sum_{i = 1}^{l - 1} a[i] + \prod_{i = l}^r a[i] + ...
- MO Memory
关于MO和OI的选拔流程 MO:省赛--联赛--国赛 省赛:各省组织,时间不同但多在4~6月.按成绩选出参加联赛选手.浙江省的省赛全称"浙江省高中数学联赛",5月进行. 联赛:旧称 ...
- CMake 教程(待完善)
Cmake 教程 写在前面 如果工程只有几个文件,直接编写Makefile更直接明了 如果使用C.C++.之外的语言,请不要使用cmake 如果使用的语言有非常完备的构建体系,不需要使用cmake C ...
- linux-centos7.6 硬盘挂载
目录 一 .功能 二.VM中设置硬盘 2.1 系统关机状态下 2.2 添加硬盘 三.系统中挂载硬盘 3.1 查看硬盘信息 3.2 硬盘分区 3.3 格式化硬盘 3.4 临时挂载硬盘 3.4 开机自动挂 ...
- rubymineIDE配置启动
debug启动 debug启动 安装插件 报错: 网络问题 下载 ruby-debug-ide-2.3.1 解压到 /home/haima/.rvm/gems/ruby-2.3.8/gems/
- SRAM、DRAM、Flash、DDR有什么区别
SRAM SRAM的全称是Static Rnadom Access Memory,翻译过来即静态随机存储器.这里的静态是指这种存储器只需要保持通电,里面的数据就可以永远保持.但是当断点之后,里面的数据 ...