当前位置: 首页 > 编程笔记 >

Java中的2种集合排序方法介绍

裴英才
2023-03-14
本文向大家介绍Java中的2种集合排序方法介绍,包括了Java中的2种集合排序方法介绍的使用技巧和注意事项,需要的朋友参考一下

直接上代码:

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块。但是当我