TreeSet和Comparator 对TreeSet排序
使用TreeSet和Comparator,编写TreeSetTestInner类,要求对TreeSet中的元素"HashSet"、"ArrayList"、"TreeMap"、"HashMap"、"TreeSet"、"LinkedList"进行升序和倒序排列,并使用匿名内部类和静态内部类分别实现。
方法一:
静态内部类
import java.util.*;
public class TreeSetTestInner{
public static void main(String[] args) {
TreeSet c = new TreeSet(new MyComparator());
c.add("HashSet");
c.add("ArrayList");
c.add("TreeMap");
c.add("HashMap");
c.add("TreeSet");
c.add("LinkedList");
Iterator it = c.iterator();
while(it.hasNext())
System.out.println(it.next());
}
static class MyComparator implements Comparator{
public int compare(Object o1, Object o2){
String s1 = (String)o1;
String s2 = (String)o2;
//升序
//return s1.compareTo(s2);
//降序
return -s1.compareTo(s2);
}
}
}
匿名内部类
import java.util.*;
public class TreeSetTestInner2{
public static void main(String[] args) {
TreeSet c = new TreeSet(new Comparator(){
public int compare(Object o1, Object o2){
String s1 = (String)o1;
String s2 = (String)o2;
//升序
//return s1.compareTo(s2);
//降序
return -s1.compareTo(s2);
}
});
c.add("HashSet");
c.add("ArrayList");
c.add("TreeMap");
c.add("HashMap");
c.add("TreeSet");
c.add("LinkedList");
Iterator it = c.iterator();
while(it.hasNext())
System.out.println(it.next());
}
}
方法二:
匿名内部类
import java.util.*;
public class TreeSetTest3 {
public static void main(String[] args){
String[] s = {"HashSet","ArrayList","TreeMap","HashMap","TreeSet","LinkedList"};
TreeSet sts = new TreeSet();
TreeSet jts = new TreeSet(new Comparator(){
public int compare(Object a, Object b){
String s1 = (String)a;
String s2 = (String)b;
if(s1.compareTo(s2) > 0){
return -1;
}
else if(s1.compareTo(s2) == 0){
return 0;
}
else{
return 1;
}
}
});
for(int i = 0; i < 6; i++){
jts.add(s[i]);
}
for(int i = 0; i < 6; i++){
sts.add(s[i]);
}
System.out.println("升序"+sts);
System.out.println("降序"+jts);
}
}
静态内部类:
import java.util.*;
public class TreeSetTest4 {
static class PaiXu{
TreeSet sts;
TreeSet jts;
public TreeSet daoxu(String[] s){
jts = new TreeSet(new Comparator(){
public int compare(Object a, Object b){
String s1 = (String)a;
String s2 = (String)b;
if(s1.compareTo(s2) > 0){
return -1;
}
else if(s1.compareTo(s2) == 0){
return 0;
}
else{
return 1;
}
}
});
for(int i = 0; i < 6; i++){
jts.add(s[i]);
}
return jts;
}
public TreeSet shunxu(String[] s){
sts = new TreeSet();
for(int i = 0; i < 6; i++){
sts.add(s[i]);
}
return sts;
}
}
public static void main(String[] args){
String[] s = {"HashSet","ArrayList","TreeMap","HashMap","TreeSet","LinkedList"};
PaiXu px = new PaiXu();
px.shunxu(s);
px.daoxu(s);
System.out.println("升序"+px.sts);
System.out.println("降序"+px.jts);
}
}
TreeSet和Comparator 对TreeSet排序的更多相关文章
- TreeSet实现Comparator接口的排序算法的分析
为了方便,用lambda表达式代替comparator接口 例子如下: public static void main(String[] args) { TreeSet<Integer> ...
- JDK学习---深入理解Comparator、TreeSet、TreeMap为什么可以排序
我本来打算仔细的去分析分析TreeSet和TreeMap排序规则,并且从底层实现和数据结构入手.当我去读完底层源码以后,我感觉我就的目标定的太大了,单单就是数据结构就够我自己写很久了,因此我决定先易后 ...
- Java基础 TreeSet()来实现数组的【定制排序】 : Comparable接口(自然排序) 或者 Comparator接口 (定制排序)
笔记: //排序真麻烦!没有C++里的好用又方便!ORZ!ORZ!数组排序还还自己写个TreeSet()和( Comparable接口(自然排序) 或者 Comparator接口 (定制排序))imp ...
- 用TreeSet和Comparator给list集合元素去重
今天在做导入功能时,看到一个感觉很好的去重算法,特分享给大家看看: 其原理利用了以下几点: 1.TreeSet里面不会有重复的元素,所以当把一个List放进TreeSet里面后,会自动去重 2.Tre ...
- Comparator.comparing比较排序
使用外部比较器Comparator进行排序 当我们需要对集合的元素进行排序的时候,可以使用java.util.Comparator 创建一个比较器来进行排序.Comparator接口同样也是一个函数式 ...
- 使用自定义Comparator对TreeSet中的数据进行多条件排序
代码记录(需求:根据店铺等级和店铺到某个点的距离进行排序,其中店铺等级由高到低,距离由近及远) 需要排序的对象Store,Store.java package com.zhipengs.work.te ...
- TreeSet,Comparator
ThreeSet能够对集合中的对象排序,当TreeSet想集合中加入一个对象时,会把它插入到有序的对象序列中. ThreeSet自带了一个排序方法,这个方法规定了一般数据的排序规则,如果用户想要规定自 ...
- 利用TreeSet给纯数字字符串排序
import java.util.Iterator;import java.util.TreeSet; /* * 给字符串中的数字排序 * String str = "10,2,11,1,3 ...
- 通过实现Comparable接口结合TreeSet来对对象自动排序
经过会遇到这样的情况,对于某个对象数组或者链表要按照一定的规则进行排序,那么我们该怎么做呢? 如遇到这样的需求: 1.需求1 对于学生对象按照年龄进行排序,年龄小的排在前面. 单单看到这样的需求,实现 ...
随机推荐
- 商人过河问题(DFS)
问题描述:3个商人带着3个仆人过河,过河的工具只有一艘小船,只能同时载两个人过河,包括划船的人.在河的任何一边,只要仆人的数量超过商人的数量,仆人就会联合起来将商人杀死并抢夺其财物,问商人应如何设计过 ...
- Swift数据类型简介(二)
整数 整数就是没有小数部分的数字,比如42和-23.整数可以是有符号(正.负.零)或者无符号(正.零). Swift 提供了8,16,32和64位的有符号和无符号整数类型.这些整数类型和 C 语言的命 ...
- LINQ查询操作符之First、FirstOrDefault、Last、LastOrDefault、ElementAt、ElementAtOrDefault、Contains、Any、All、Coun
·First - 返回集合中的第一个元素:不延迟 ·FirstOrDefault - 返回集合中的第一个元素(如果没有则返回默认值):不延迟 ·Last - 返回集合中的最后一个元素:不延迟 ·Las ...
- python核心编程学习记录之序列(字符串元组列表)
可以在元组中放入可变类型如列表,然后修改列表来修改元组
- vm虚拟机启动失败 Global\vmx86
workstation12 PRO 启动虚拟机异常报错:无法打开内核设备“\\.\Global\vmx86”: 系统找不到指定的文件 解决方法,启动windows系统服务:
- webApp移动开发之REM
最近发现一偏很好的文章,关于webAPP开发REM 一个css单位: 来自腾讯ISUX; web app变革之rem
- java中如何获取昨天的当前日期
在java里,获取昨天的当前日期,可以采用calendar来做,也可以采用date来做:如下: 1.采用calendar来做: Calendar cal=Calendar.getInstance(); ...
- A feature in Netsuite Reports > Financial > Balance Sheet
最新版本的Customize balance sheet page Left side > Layout > Add Reference Row Then in right side, y ...
- R----Shiny包介绍学习
为什么用Shiny Shiny让数据分析师写完分析与可视化代码后,稍微再花几十分钟,就可以把分析代码工程化,将分析成果快速转化为交互式网页分享给别人.所以,如果你是一名使用R的数据分析师,选择Shin ...
- Oracle的select使用
1.select : 语法: select [distinct] {*,column [alias],...} from table 注:[]括起来的内容代表可有可无 * 代表所有列 distinct ...