package TreeSetTest;

import java.util.Iterator;
import java.util.TreeSet; import javax.management.RuntimeErrorException; /*
可以对set集合中的元素进行排序,其底层的数据结构是二叉树,
保证元素唯一性的依据是compareTo和return 0; TreeSet排序的第一种方式
让元素自身具备比较性
元素需要实现Comparable接口,覆盖compareTo方法
这种方式也成为元素的自然顺序,或者叫做默认顺序 TreeSet排序的第二种方式
当元素自身不具备比较性时,或者具备的比较性不是所需的
这时就需要让集合自身具备比较性
在集合初始化时,就有了比较方式 记住:当比较时,如果主要条件相同,就比较次要条件
*/ class Student implements Comparable // 该接口强制让对象具有比较性
{
private String name;
private int age; Student(String name,int age)
{
this.name = name;
this.age = age;
} public int compareTo(Object obj)
{
/* if (!(obj instanceof Student))
{
throw new RuntimeException("不是学生对象");
}
Student s = (Student)obj;
// System.out.println(this.name+"=====Compare====="+this.age);
if (this.age >s.age)
{
return 1;
}
else if (this.age == s.age) {
// 如果年龄相同比较姓名
return this.name.compareTo(s.name);
}
else {
return -1;
} */
return -1;
} public String getname()
{
return this.name;
} public int getage()
{
return age;
}
} public class TreeSetDemo
{
public static void main(String[] args)
{
TreeSet<Student> tsSet =new TreeSet<Student>(); tsSet.add(new Student("as", 12));
tsSet.add(new Student("fvhgj",45));
tsSet.add(new Student("ert", 15));
tsSet.add(new Student("wenjia", 31));
tsSet.add(new Student("wejia", 1)); Iterator<Student> iterator = tsSet.iterator(); while (iterator.hasNext())
{
Student stu = (Student)iterator.next();
System.out.println(stu.getage()+"======"+stu.getname());
}
}
} ////////////////////////////////////////////
////////////////////////////////////////////
package TreeSetTest; import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet; /*
当元素自身不具备比较性,或者具备的比较性不是所需要的。
这时需要让容器自身具备比较性。
定义了比较器,将比较器对象作为参数传递给TreeSet集合的构造函数。 当两种排序都存在时,一比较器为主 定义一个类,实现Comparator接口,覆盖compare方法
二叉树都是以 return 0;判断元素是否相等
*/ public class TreeSetDemoTwo
{
public static void main(String[] args)
{
TreeSet<Student> tsSet = new TreeSet<Student>(new MyCompare()); tsSet.add(new Student("wenjai10", 29));
tsSet.add(new Student("wenjai11", 28));
tsSet.add(new Student("wenjai12", 27));
tsSet.add(new Student("wenjai13", 26));
tsSet.add(new Student("wenjai11", 21)); Iterator<Student> it = tsSet.iterator();
while (it.hasNext())
{
Student student = (Student) it.next();
System.out.println(student.getname()+"======"+student.getage()); }
}
} class MyCompare implements Comparator
{
public int compare(Object o1,Object o2)
{
Student s1 = (Student)o1;
Student s2 = (Student)o2; int num = s1.getname().compareTo(s2.getname());
if (num == 0)
{
// 由于整数类型也有比较方法,所以将整数封装成对象
return new Integer(s1.getage()).compareTo(new Integer(s2.getage()));
/*
if (s1.getage()>s2.getage())
{
return 1;
}
if (s1.getage() == s2.getage())
{
return 0;
}
return -1;
*/
}
return num;
}
} ///////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////
package TreeSetTest; import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet; /*
练习: 按照字符串长度排序 字符串本身具有比较性,但是它的比较方式不是所需的 这时就只能用比较器
*/ public class TreeSetPractice_One
{ public static void main(String[] args)
{
TreeSet<String> ts = new TreeSet<String>(new stringLenCompare()); ts.add("asd");
ts.add("bb");
ts.add("ba");
ts.add("ityior");
ts.add("hysdhbgg"); Iterator<String> it = ts.iterator();
for (String string : ts)
{
System.out.println(string);
}
}
} class stringLenCompare implements Comparator
{
@Override
public int compare(Object o1, Object o2)
{
// TODO Auto-generated method stub
String str1 = (String)o1;
String str2 = (String)o2; /*
if (str1.length()>str2.length())
{
return 1;
}
if(str1.length() == str2.length())
{
return 0;
}
*/
int num = new Integer(str1.length()).compareTo(new Integer(str2.length()));
if (num == 0)
{
return str1.compareTo(str2);
}
return num;
// return 0;
}
}

  

Java TreeSet集合排序 && 定义一个类实现Comparator接口,覆盖compare方法 && 按照字符串长度排序的更多相关文章

  1. JAVA 类的定义(定义一个类,来模拟“学生”)

    package Code413;/*定义一个类,来模拟“学生”属性 (是什么) 姓名 年龄行为(能做什么) 吃饭 睡觉 学习对应到Java的类当中 成员变量(属性) String nanme; //姓 ...

  2. Java中是否可以调用一个类中的main方法?

    前几天面试的时候,被问到在Java中是否可以调用一个类中的main方法?回来测试了下,答案是可以!代码如下: main1中调用main2的主方法 package org.fiu.test; impor ...

  3. 类的继承和多态性-编写Java应用程序,定义Animal类,此类中有动物的属性:名称 name,腿的数量legs,统计动物的数量 count;方法:设置动物腿数量的方法 void setLegs(),获得腿数量的方法 getLegs(),设置动物名称的方法 setKind(),获得动物名称的方法 getKind(),获得动物数量的方法 getCount()。定义Fish类,是Animal类的子类,

    编写Java应用程序,定义Animal类,此类中有动物的属性:名称 name,腿的数量legs,统计动物的数量 count;方法:设置动物腿数量的方法 void setLegs(),获得腿数量的方法 ...

  4. 怎样用Javascript定义一个类

    其实Javascript中没有类这个定义,但是有类这个概念.很多人都写过这样的代码,对,没错,就是如下代码,清晰的不能再清晰了,就是一个关键字 function,然后定义一个方法名,方法名后紧跟一对括 ...

  5. Python3.x:定义一个类并且调用

    Python3.x:定义一个类并且调用 1,定一个类Shrjj(其中有属性:name, jjzt,fbsjj,etf,lof,fjlof): class Shrjj(object): def __in ...

  6. java多线程并发去调用一个类的静态方法安全性探讨

    java多线程并发去调用一个类的静态方法安全性探讨 转自:http://blog.csdn.net/weibin_6388/article/details/50750035   这篇文章主要讲多线程对 ...

  7. 定义一个类:实现功能可以返回随机的10个数字,随机的10个字母, 随机的10个字母和数字的组合;字母和数字的范围可以指定,类似(1~100)(A~z)

    #习题2:定义一个类:实现功能可以返回随机的10个数字,随机的10个字母, #随机的10个字母和数字的组合:字母和数字的范围可以指定 class RandomString(): #随机数选择的范围作为 ...

  8. Java基础-接口.编写2个接口:InterfaceA和InterfaceB;在接口InterfaceA中有个方法void printCapitalLetter();在接口InterfaceB中有个方法void printLowercaseLetter();然 后写一个类Print实现接口InterfaceA和InterfaceB,要求 方法 实现输出大写英文字母表的功能,printLowerca

    #34.编写2个接口:InterfaceA和InterfaceB:在接口InterfaceA中有个方法void printCapitalLetter():在接口InterfaceB中有个方法void ...

  9. 代码实现:定义一个文件输入流,调用read(byte[] b)方法,将a.txt文件中的内容打印出来(byte数组大小限制为5)

    package com.loaderman.test; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; im ...

随机推荐

  1. iOS 主动抛出异常

    http://blog.csdn.net/jymn_chen/article/details/38096749 http://blog.sina.com.cn/s/blog_7270a06c0101b ...

  2. vs2012中的小技巧2

    vs代码前面出现.......,解决方法是:点击菜单编辑——高级——查看空白

  3. [转] 如何让CloudStack使用KVM创建Windows实例成功识别并挂载数据盘

    在使用kvm给windows虚拟机动态挂载virtio类型的硬盘时候遇到问题,通过下面的文章知道需要安装virtio驱动,从而解决问题使挂在正常,在此处mark一下 问题产生背景: 使用CloudSt ...

  4. List学习笔记

    List 特点:1.有序.2.可重复. ArrayList: 底层是数组,数组是有下标的. 会自动扩容,底层默认初始化容量是10,扩大之后的容量预设是原来容量的一半(jdk 1.8).以前好像是原容量 ...

  5. Java程序员常犯的10个错误

      本文总结了Java程序员常犯的10个错误. #1. 把Array转化成ArrayList 把Array转化成ArrayList,程序员经常用以下方法: List<String> lis ...

  6. 使用 System.Transactions 进行事物管理

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  7. python模块的打包setuptools

    样例代码:新建test.py文件,内容如下: print "show me" 新建一个setup.py编译文件,内容如下: from distutils.core import s ...

  8. Struts2的那些小细节

    1.result中传多个参数,&不允许使用需要转义&即多个参数之间用&隔开 <result type="redirectAction">show ...

  9. 一分钟完成MySQL5.7安装部署

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://suifu.blog.51cto.com/9167728/1855415 Part ...

  10. PHP连接和拆分数组array_combine()和array_slice()用法示例

    一提起数组,可能很多PHP初学者会觉得难,但开发一些高级应用的时候,又离不开数组的使用.下面就来说下,PHP使用array_combine()函数来连接数组.用array_slice()函数来拆分数组 ...