直接上代码:
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; /** * * <p> * ClassName CollectionsSort * </p> * <p> * Description 主要介绍两种集合的排序算法<br/> * 第一:java.util.Collections.sort(java.util.List),要求所排序元素必须实现java.lang.Comparable接口 <br/> * 第二:java.util.Collections.sort(java.util.List, java.util.Comparator),这个方法要求实现java.util.Comparator接口 <br/> * 第三:下面的例子使用的是对int型属性排序,对String属性排序可以使用以下方法<br/> * public int compareTo(Cat o){return this.getName().compareTo(o.getName(0);}<br/> * 第四:compareTo()函数的说明 <br/> * 如果 结果;<br/> * <0 a<b ;<br/>= * ==0 a==b;<br/> * >=0 a>b; * </p> * * @author wangxu wangx89@126.com * <p> * Date 2014-9-16 下午04:52:57 * </p> * @version V1.0 * */ public class CollectionsSort { public static void main(String[] args) { // method1();测试第一个方法 method2();// 测试第二个方法 } public static void method1() { List<Cat> list = new ArrayList<Cat>(); Cat c = new Cat("a", 10); list.add(c); c = new Cat("b", 20); list.add(c); c = new Cat("c", 3); list.add(c); // 升序排列输出 Collections.sort(list); System.out.println(list); // 降序排列输出 Collections.sort(list, Collections.reverseOrder()); System.out.println(list); } public static void method2() { List<Cat> list = new ArrayList<Cat>(); Cat c = new Cat("a", 10); list.add(c); c = new Cat("b", 20); list.add(c); c = new Cat("c", 3); list.add(c); Comparator<Cat> catComparator = new Cat(); // 升序排列输出 Collections.sort(list, catComparator); System.out.println(list); // 降序排列输出 catComparator = Collections.reverseOrder(catComparator); Collections.sort(list, catComparator); System.out.println(list); } } class Cat implements Comparable<Cat>, Comparator<Cat> { private int age; private String name; public Cat() { } public Cat(String name, int age) { this.age = age; this.name = name; } public int getAge() { return this.age; } public String getName() { return this.name; } public void setAge(int age) { this.age = age; } public void setName(String name) { this.name = name; } // 实现了Comparable接口,不要重写该方法 @Override public int compareTo(Cat o) { // TODO Auto-generated method stub return this.age - o.age; } @Override public String toString() { // TODO Auto-generated method stub return "名字:" + getName() + ",年龄:" + getAge(); } // 实现了Comparator接口,需要重写该方法 @Override public int compare(Cat o1, Cat o2) { // TODO Auto-generated method stub return o1.getAge() - o2.getAge(); } }
本文向大家介绍用Java集合中的Collections.sort方法如何对list排序(两种方法),包括了用Java集合中的Collections.sort方法如何对list排序(两种方法)的使用技巧和注意事项,需要的朋友参考一下 第一种是list中的对象实现Comparable接口,如下: 测试一下: 输出结果如下 a b 第二种方法是根据Collections.sort重载方法来实现,例如:
问题内容: 我有一个Java集合: 现在在显示列表之前有一个字段,我想按此排序此集合。 有什么办法可以做到吗? 问题答案: 使用比较器: 此外,如果实现,则只需使用 使用JDK 8,语法要简单得多。 更简单 最简单的 显然,初始代码也可以用于JDK 8。
主要内容:1 集合元素的排序,2 Collections sort方法,3 字符串正序排序,4 字符串倒序排序,5 包装类型排序,6 自定义对象排序1 集合元素的排序 我们可以对以下元素进行排序: 字符串对象 包装类对象 用户自定义对象 Collections类提供用于对集合的元素进行排序的静态方法。如果集合元素为Set类型,则可以使用TreeSet。但是,我们无法对List的元素进行排序。Collections类提供用于对List类型元素的元素进行排序的方法。 2 Collections so
问题内容: 我是Java的初学者。请建议可以/应该使用哪些集合来维护Java中的排序列表。我尝试了和,但它们不是我想要的。 问题答案: 这来得很晚,但是JDK中有一个类只是为了获得排序列表。它被命名(与其他Sorted*接口有些混乱)“ ”。它可以排序或使用Comparator。 与 sorted using 的区别在于,通过使用堆数据结构,这将始终保持部分顺序,具有O(log(n))插入性能,而
我正在研究一个扑克牌洗牌的问题,并找到了两个解决方案。 目标是将存储在阵列中的所有52张扑克牌作为卡对象进行洗牌。卡类具有与其关联的id和名称。 现在,一种方法是使用for循环迭代,然后在临时卡对象持有者和随机数生成器的帮助下,我们可以交换两个对象。这一直持续到我们到达一半的卡片。 另一种方法是使用随机生成器编号实现可比较的覆盖比较方法,因此每次调用该方法时都会得到随机响应。 你觉得哪条路更好?
我在我的应用程序中有以下合并排序代码。我对递归方法在不满足if条件时从if块中出来后如何再次调用感到非常困惑。 我调试了我的代码,但我仍然没有得到它。调用mergesort(0,号-1)的排序方法首先从mergesort(0,5)开始。低小于高,中间是2,所以接下来运行mergesort(0,2)。这一直持续到我们有mergesort(0,0),在这种情况下,低不小于高,所以它来自if块。但是当我