java对ArrayList排序代码示例
作者:sunmenggmail 发布时间:2023-11-24 20:14:21
标签:java,arraylist,排序
不废话了,直接给大家贴代码了。
class term {
String str;
int id;
public term(String str, int id) {
this.str = str;
this.id = id;
}
public String toString() {
return str+" "+id;
}
}
class sterm implements Comparable{
String str;
int id;
public sterm(String str, int id) {
this.str = str;
this.id = id;
}
public int compareTo(Object o) {
return ((sterm)o).id - id;
}
public String toString() {
return str+" "+id;
}
}
//method1: explicit implements Comparator
class termComparator implements Comparator {
public int compare (Object o1, Object o2) {
return ((term)o1).id - ((term)o2).id;
}
}
public class t1 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
// ArrayList<Integer> arr = new ArrayList<Integer>( Arrays.asList(3,1,3,7,8,0));
//
// Collections.sort(arr, new Comparator(){
//
// public int compare(Object o1, Object o2){
// return new Double((Integer)o1).compareTo(new Double ((Integer)o2));
// }
// });
//method1
List<term> ls = new ArrayList<term>();
ls.add(new term("a",1));
ls.add(new term("b",5));
ls.add(new term("c",2));
ls.add(new term("d",2));
ls.add(new term("e",3));
ls.add(new term("f",0));
Collections.sort(ls, new termComparator());
System.out.println(ls);//[f 0, a 1, c 2, d 2, e 3, b 5]
//method2: anonymous implements
Collections.sort(ls, new Comparator(){
public int compare(Object o1, Object o2){
return ((term)o2).id - ((term)o1).id;
}
});
System.out.println(ls);//[b 5, e 3, c 2, d 2, a 1, f 0]
//method3:instantiate a Comparator template
Comparator<term> termCmp = new Comparator<term>() {
public int compare(term t1, term t2) {
return t1.id - t2.id;
}
};
Collections.sort(ls, termCmp);
System.out.println(ls);//[f 0, a 1, c 2, d 2, e 3, b 5]
//method4:element implements Comparable
List<sterm> lss = new ArrayList<sterm>();
lss.add(new sterm("a",1));
lss.add(new sterm("b",5));
lss.add(new sterm("c",2));
lss.add(new sterm("d",2));
lss.add(new sterm("e",3));
lss.add(new sterm("f",0));
Collections.sort(lss);
System.out.println(lss);//[b 5, e 3, c 2, d 2, a 1, f 0]
}
}
PrioriyQueue的用法和上述的排序类似,有三种方法:
class WordFreq implements Comparable{
public String wd;
public int freq;
public WordFreq(String wd, int freq) {
this.wd = wd;
this.freq = freq;
}
public int compareTo(Object o) {
return ((WordFreq)o).freq - freq;
}
public String toString() {
return wd+" "+freq;
}
}
public class testt {
public static void main(String[] args) {
// TODO Auto-generated method stub
PriorityQueue<WordFreq> pq = new PriorityQueue<WordFreq>();
pq.offer(new WordFreq("aaa", 3));
pq.offer(new WordFreq("bbb", 4));
pq.offer(new WordFreq("ccc",1));
while(pq.peek() != null) {
System.out.println(pq.poll());
}//从大到小输出
}
}
注意,
for (WordFreq wf : pq) {
System.out.println(wf);
}
并不保证遍历的有序
如果List<String> ls 进行排序的话,不需要写Comparator, 因为String本身有compareTo的实现。


猜你喜欢
- 在使用AbstractRoutingDataSource配置多数据源时,发现使用@aspect配置的DataSourceSwitchAspe
- 参考文献:https://www.jb51.net/article/232858.htm使用springboot 2 构建项目,调试代码的时
- Android Studio 3.6正式版已经发布https://android-developers.googleblog.com/202
- 关于DocumentCompleted事件,MSDN给出的解释是在文档加载完毕后执行,但是在我的程序中DocumentCompleted却被
- 1.WinMergeWinMerge是一款运行于Windows系统下的文件比较和合并工具https://winmerge.org/downl
- Java动态数组Arraylist存放自定义数据类型class Point{ int x; int y; public Point(int
- Spring是什么?Spring是一个轻量级Java开发框架,最早有Rod Johnson创建,目的是为了解决企业级应用开发的业务逻辑层和其
- 介绍我们都知道函数是程序中的基本模块,代码段。那高阶函数呢?听起来很好理解吧,就是函数的高阶(级)版本。它怎么高阶了呢?我们来看下它的基本定
- 在处理大文件时,如果利用普通的FileInputStream 或者FileOutputStream 抑或RandomAccessFile 来
- 1:Group的功能Group可以管理一组节点Group可以对管理的节点进行增删改查的操作Group可以管理节点的属性1.2:看看JDKSE
- 前言在一些日常业务中,会遇到一些琐碎文件需要统一打包到一个压缩包中上传,业务方在后台接收到压缩包后自行解压,然后解析相应文件。而且可能涉及安
- 详解Java使用super和this来重载构造方法实例代码://父类 class anotherPerson{ String
- tcp一般用于维持一个可信任的连接,比起udp更为安全可靠,在vs.net,分别有tcpclient和udpclient以及tcpliste
- 本文和大家一起做一个带箭头的圆角矩形菜单,大概长下面这个样子:要求顶上的箭头要对准菜单锚点,菜单项按压反色,菜单背景色和按压色可配置。最简单
- 当我们在做前后端分离的开发时,在使用fetch交换数据的时候,提示Access-Control-Allow-Origin跨域问题,解决方案跟
- 如下:public Object invokeMethod(String className, String methodName,Obje
- 前言昨晚想在Android应用中增加一个int映射到String的字典表,使用HashMap实现的时候,Eclipse给出了一个警告,昨晚项
- java 抛出异常处理的方法为了避免调用的人不知道有异常,才抛出异常的,所以是谁掉用的久在哪里处理。说的对吗对.1、throws关键字通常被
- 本文将介绍一段实例代码,来讲解利用正则表达式使C#判断输入日期格式是否正确的方法。希望这段代码能对大家有所帮助。 通常我们在用C#
- 1. 线程的5种状态从操作系统层面上,任何线程一般都具有五种状态,即创建、就绪、运行、阻塞、终止。(1) 新建状态(NEW)在程序中用构造方