Java TreeSet集合排序 && 定义一个类实现Comparator接口,覆盖compare方法 && 按照字符串长度排序
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方法 && 按照字符串长度排序的更多相关文章
- JAVA 类的定义(定义一个类,来模拟“学生”)
package Code413;/*定义一个类,来模拟“学生”属性 (是什么) 姓名 年龄行为(能做什么) 吃饭 睡觉 学习对应到Java的类当中 成员变量(属性) String nanme; //姓 ...
- Java中是否可以调用一个类中的main方法?
前几天面试的时候,被问到在Java中是否可以调用一个类中的main方法?回来测试了下,答案是可以!代码如下: main1中调用main2的主方法 package org.fiu.test; impor ...
- 类的继承和多态性-编写Java应用程序,定义Animal类,此类中有动物的属性:名称 name,腿的数量legs,统计动物的数量 count;方法:设置动物腿数量的方法 void setLegs(),获得腿数量的方法 getLegs(),设置动物名称的方法 setKind(),获得动物名称的方法 getKind(),获得动物数量的方法 getCount()。定义Fish类,是Animal类的子类,
编写Java应用程序,定义Animal类,此类中有动物的属性:名称 name,腿的数量legs,统计动物的数量 count;方法:设置动物腿数量的方法 void setLegs(),获得腿数量的方法 ...
- 怎样用Javascript定义一个类
其实Javascript中没有类这个定义,但是有类这个概念.很多人都写过这样的代码,对,没错,就是如下代码,清晰的不能再清晰了,就是一个关键字 function,然后定义一个方法名,方法名后紧跟一对括 ...
- Python3.x:定义一个类并且调用
Python3.x:定义一个类并且调用 1,定一个类Shrjj(其中有属性:name, jjzt,fbsjj,etf,lof,fjlof): class Shrjj(object): def __in ...
- java多线程并发去调用一个类的静态方法安全性探讨
java多线程并发去调用一个类的静态方法安全性探讨 转自:http://blog.csdn.net/weibin_6388/article/details/50750035 这篇文章主要讲多线程对 ...
- 定义一个类:实现功能可以返回随机的10个数字,随机的10个字母, 随机的10个字母和数字的组合;字母和数字的范围可以指定,类似(1~100)(A~z)
#习题2:定义一个类:实现功能可以返回随机的10个数字,随机的10个字母, #随机的10个字母和数字的组合:字母和数字的范围可以指定 class RandomString(): #随机数选择的范围作为 ...
- Java基础-接口.编写2个接口:InterfaceA和InterfaceB;在接口InterfaceA中有个方法void printCapitalLetter();在接口InterfaceB中有个方法void printLowercaseLetter();然 后写一个类Print实现接口InterfaceA和InterfaceB,要求 方法 实现输出大写英文字母表的功能,printLowerca
#34.编写2个接口:InterfaceA和InterfaceB:在接口InterfaceA中有个方法void printCapitalLetter():在接口InterfaceB中有个方法void ...
- 代码实现:定义一个文件输入流,调用read(byte[] b)方法,将a.txt文件中的内容打印出来(byte数组大小限制为5)
package com.loaderman.test; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; im ...
随机推荐
- Web开发中需要了解的东西
在StackExchange上有人问了这样一个问题:What should every programmer know about web development?(关于Web开发,什么是所有程序员需 ...
- tp框架设置 mysql数据库的端口号
<?php return array( //'配置项'=>'配置值' SHOW_PAGE_TRACE=>true,//开启trace信息 'DB_TYPE' => 'mysql ...
- cocos2d-x 定时器selector的使用 :schedule的使用
在游戏设计时,我们需要不断的改变屏幕显示来反映游戏操作的效果,最简单的就是提示用户已经进行的游戏时间.为此,我们需要使用cocos2d-x内置的任务调度机制,即CCNode的schedule成员函数. ...
- 单纯觉得是篇好文——跨终端Web之Hybrid App
[reference]http://www.infoq.com/cn/articles/hybrid-app#theCommentsSection 编者按:InfoQ开设新栏目“品味书香”,精选技术书 ...
- Elasticsearch基础教程
Reference: http://blog.csdn.net/cnweike/article/details/33736429 基础概念 Elasticsearch有几个核心概念.从一开始理解这些概 ...
- UVa 336 - A Node Too Far
题目大意:在计算机网络中,每条信息都有一个TTL值,在信息到达一个节点时,TTL值首先减1,如果TTL为0,则丢弃该信息报文.给一个网络的配置,给定源点和TTL值,判断该网络中有多少节点不可到达. 无 ...
- UIStackView属性解释
Distribution 分布: Fill:填充,会根据优先级来压缩或伸长元素 Fill Equal:全都相等,并且都填充满 Fill Proportionally:按比例填充,根据元素的内容多少的比 ...
- Bash's Big Day
Bash has set out on a journey to become the greatest Pokemon master. To get his first Pokemon, he we ...
- iOS 之 后台下载,前台显示模式,双 block
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //耗时的操作 NSURL *url ...
- JavaScript中typeof和instanceof深入详解
这次主要说说javascript的类型判断函数typeof和判断构造函数原型instanceof的用法和注意的地方. typeof 先来说说typeof吧.首先需要注意的是,typeof方法返回一个字 ...