TreeSet比较器
来源:互联网 发布:mac虚拟机共享 编辑:程序博客网 时间:2024/05/16 06:30
import java.util.*;/*TreeSet是有序的 在存入对象的过程中,要定义按照什么来排序存入的类要实现一个Comparable接口 方法compareTo 大于 返回正数小于 返回负数等于 返回零*/public class Demo {public static void main(String[] args) {TreeSet ts= new TreeSet(new Comp());ts.add(new Person("hk3",13));ts.add(new Person("hk1",11));ts.add(new Person("hk2",12));ts.add(new Person("hk4",12));ts.add(new Person("hk4",12));ts.add(new Person("hk0",10));Iterator it=ts.iterator();while(it.hasNext()){Person p=(Person)it.next();sop(p.getName()+" "+p.getAge());}}public static void sop(Object obj){System.out.println(obj);}}class Comp implements Comparator//比较器。。。。。。。。。。{public int compare(Object o1,Object o2){Person p1=(Person)o1;Person p2=(Person)o2;int num =p1.getName().compareTo(p2.getName());if (num==0){return p1.getAge()-p2.getAge();}return num;}}class Person implements Comparable//比较性{private String name;private int age;Person(String name,int age){this.name=name;this.age=age;}public void setName(String name){this.name=name;}public String getName(){return name;}public void setAge(int age){this.age=age;}public int getAge(){return age;}public int compareTo(Object obj)//这里!!!这里这里!!{if(!(obj instanceof Person))throw new RuntimeException("shaazhes");Person p=(Person)obj;//要转换成相同类型的才能进行比较//System.out.println(this.age+"-----"+p.age);//比较过程if(this.age>p.age)return 1;if(this.age==p.age){return this.name.compareTo(p.name);//当年龄一样时 再比较一次姓名}return -1;}}
阅读全文
0 0
- TREESET比较器比较
- TreeSet比较器
- TreeSet (比较器)
- TreeSet比较器
- java TreeSet中的比较器
- TreeSet比较器的用法
- TreeSet 使用 Comparator 比较器
- TreeSet 下创建比较器进行比较
- TreeSet 使用指定比较器进行排序
- TreeSet集合中自定义比较器
- 集合框架--TreeSet集合Comparator比较器
- 【TreeSet】自然排序与比较器排序
- TreeSet与HashSet比较
- 比较HashSet和TreeSet
- HashSet TreeSet比较
- Java基础15:treeset;排序方法-比较器;泛型;
- J2SE学习笔记:J2SE重点难点,TreeSet比较器
- TreeSet(对象排序功能)和自定义比较器
- 编程实现:两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
- 【Docker】配置docker-compose(五)
- 每天一道LeetCode-----将数组/链表后k个元素移动到前面
- 一次难忘的蹭课
- I can 前端-04 JavaScript
- TreeSet比较器
- 用nginx的反向代理机制解决前端跨域问题
- url
- Dijkstra算法
- linux的find命令
- anaconda+python 下进行FFT算法的总结
- OSG 求射线与模型的交点
- Effective Java
- 面向切面编程AOP的浅显理解(一)