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 ...
随机推荐
- WeakHashMap和Java引用类型详细解析
WeakHashMap是种弱引用的HashMap,这是说,WeakHashMap里的key值如果没有外部强引用,在垃圾回收之后,WeakHashMap的对应内容也会被移除掉. 1.1 Java的引用类 ...
- 完美分割字符串,实现字符串的splict功能
class Str:Client_C { string val; string[] str = new string[100]; public void StrT1() { //1.正常情况 //2. ...
- mongodb 导入数据库文件
吐槽一下: 这个导入现有数据文件弱爆了... 直接将要导入的数据文件放到mongodb下的db目录下就完事了...O(∩_∩)O哈哈~ 例如: 将shop_suning (shopdb_suning ...
- gulp学习指南之CSS合并、压缩与MD5命名及路径替换
1.引入插件 var gulp = require('gulp'), // uglify = require('gulp-uglify'), concat = require('gulp-concat ...
- mybatis 参数为list时,校验list是否为空, mybatis ${}与#{}的区别,Mybatis sql in
1.mybatis 参数为list时,校验list是否为空 2. mybatis ${}与#{}的区别 简单来说#{} 解析的是占位符?可以防止SQL注入, 比如打印出来的语句 select * fr ...
- js控制div显示与隐藏
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- PHP文件夹文件拷贝/复制函数 dir_copy($src = '', $dst = '')
/* * 文件夹文件拷贝 * * @param string $src 来源文件夹 * @param string $dst 目的地文件夹 * @return bool */ function dir ...
- C++第三天学习
回顾: 类和对象 class 类名 { public: private: 在类的类部可以访问,在类的外部不能直接访问. protected: 在类的类部可以访问,在类的外部不能直接访问,其子类可以访问 ...
- 使用Eclipse开发及测试Spark的环境搭建及简单测试
一.下载专门开发的Scala的Eclipse 1.下载地址:http://scala-ide.org/download/sdk.html,或链接:http://pan.baidu.com/s/1hre ...
- atoi
, KInvalid}; int g_nStatus=kValid; int StrToInt(const char *str) { g_nStatus=KInvalid; ; if((str!=NU ...