课题

针对单词进行排序,先按字母的长度排序,长者在前;

在长度相等的情况下,按字典降序排序。

例如,有单词序列“apple banana grape orange”,排序后输出结果应为“orange banana grape apple”。

代码

package exp1;

import java.util.List;
import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Comparator;
import java.util.TreeSet;
import java.util.stream.Collector; class word implements Comparable {
public String text;
public int len;
public word() {
// TODO Auto-generated constructor stub
this.text = null;
len = 0;
}
public word(String text) {
this.text = text;
this.len = text.length();
}
public String toString() { //println 打印字符串 先把"输出"转型成字符串:使用valueof 调用了obj.toString之后返回字符串
return text + ":" + len;
}
public int compareTo(Object obj) {
word anothorWord = (word) obj; //父类型转型
if(this.len > anothorWord.len) return -1;
else if(this.len < anothorWord.len) return 1;
int cmpFlag = this.text.compareTo(anothorWord.text);
return -cmpFlag;
} } class myTreeComparator implements Comparator{ //定制排序
//用obj2 和 obj1 比较,obj2是主,和其他obj1比较,
public int compare(Object obj1,Object obj2) {
String s1 = (String) obj1; //父转子类型
String s2 = (String) obj2;
if(s2.length() > s1.length()) return 1;//先比较长度
else if(s2.length() < s1.length()) return -1;
int cmpFlag = s2.compareTo(s1);//按字典序比较字符串
return cmpFlag; //compareTo约定 返回值:负数小于,0相等,正数大于
}
} class myArrayCompartor implements Comparator{ //定制ArrayList的排序规则
public int compare(Object obj1,Object obj2) {
word s1 = (word) obj1;
word s2 = (word) obj2;
if(s2.len > s1.len) return 1;
else if(s2.len < s1.len) return -1;
int cmpFlag = s2.text.compareTo(s1.text);
return cmpFlag;
}
} public class hellotest { public static void main(String args[]) {
TreeSet<word> tre = new TreeSet<word>(); //测试泛型 和下面写法的不同点
// TreeSet tre2 = new TreeSet();//默认按字典序排序
tre.add(new word("grape"));
// tre.add(1213); //出错
/*
* 方法1:使用集合类排序, 实现comparable重写compareTo方法, 或者使用Compartor定制排序器
* 方法2:使用工具类Array排序, 同上
*/
//:自然排序,存储元素的自定义和类实现Comparable接口,重写compareTo方法
TreeSet tre1 = new TreeSet();
// tre1.add(112);
tre1.add(new word("apple"));
tre1.add(new word("orange"));
tre1.add(new word("banana"));
tre1.add(new word("grape"));
System.out.println("Treeset实现comparable接口:");
System.out.println(tre1); //传入compartor接口实现定制排序规则
TreeSet tre2 = new TreeSet(new myTreeComparator()); //传入匿名类 覆写compare方法
tre2.add("apple");
tre2.add("orange");
tre2.add("banana");
tre2.add("grape");
System.out.println("Treeset实现compartor接口:");
System.out.println(tre2); //打印成数组 //使用Lambda表达式定制排序规则
TreeSet tre3 = new TreeSet((obj1,obj2)->{
String s1 = (String) obj1;
String s2 = (String) obj2;
if(s2.length() > s1.length()) return 1;//先比较长度
else if(s2.length() < s1.length()) return -1;
return s2.compareTo(s1);//字符串降序
});
tre3.add("apple");
tre3.add("orange");
tre3.add("banana");
tre3.add("grape");
System.out.println("Treeset使用Lambada表达式实现compartor接口:");
tre3.forEach(obj->System.out.println("tre3: " + obj)); //List集合的sort排序
ArrayList<word> arlArrayList = new ArrayList<word>();
arlArrayList.add(new word("apple"));
arlArrayList.add(new word("orange"));
arlArrayList.add(new word("banana"));
arlArrayList.add(new word("grape"));
//ArrayList 继承重写父接口 List的sort方法,需传入comparator接口参数, 实际上也是调用Arrays工具类的sort
//ArrayList的sort方法,再调用工具类Array的Arrays.sort((E[]) elementData, 0, size, c);
arlArrayList.sort(new myArrayCompartor());
System.out.println("Treeset使用Lambada表达式实现compartor接口:");
System.out.println(arlArrayList); //方法2:使用工具类Arrays的sort方法对数组排序 asList返回一个ArrayList new ArrayList(collection) 接收一个集合 使用底层copy数据
//Arrays.asList返回类型是ArrayList 听说过asList的坑:返回的ArrayList无法再添加新元素 所以这里使用new ArrayList(Arrays.asList) 包装一层就可以再添加新元素啦
List<word> list = new ArrayList<word>(Arrays.asList(new word("apple"),new word("orange"),new word("banana"),new word("grape"))); //asList接收可变长度参数
word[] arr = new word[list.size()];
list.toArray(arr); // return an array containing the elements of this list
Arrays.sort(arr); //使用工具类Arrays的sort方法对数组排序 1.可以传入自定义的Comparator,2.也可以在自定义类里实现Comparable重写compare方法
//底层遗留归并排序 新二分排序
for(int i=0;i<arr.length;i++) System.out.println(arr[i]);
}
}

Java实现单词自定义排序|集合类、工具类排序、comparable、comparator接口的更多相关文章

  1. 在JAVA中自定义连接数据库的工具类

    为什么要自定义数据库连接的工具类: 在开发中,我们在对数据库进行操作时,必须要先获取数据库的连接,在上一篇随笔中提到的获取数据库连接的步骤为: 1.定义好4个参数并赋值 2.加载驱动类 3.获取数据库 ...

  2. java.util.Arrays----操作数组的工具类

    java.util.Arrays操作数组的工具类,里面定义了很多操作数组的方法 1.boolean equals(int[] a,int[] b):判断两个数组是否相等. 2.String toStr ...

  3. Java判断不为空的工具类总结

    1.Java判断是否为空的工具类,可以直接使用.包含,String字符串,数组,集合等等. package com.bie.util; import java.util.Collection; imp ...

  4. Java字符串转16 进制工具类Hex.java

    Java字符串转16 进制工具类Hex.java 学习了:https://blog.csdn.net/jia635/article/details/56678086 package com.strin ...

  5. Java中的AES加解密工具类:AESUtils

    本人手写已测试,大家可以参考使用 package com.mirana.frame.utils.encrypt; import com.mirana.frame.constants.SysConsta ...

  6. java里poi操作excel的工具类(兼容各版本)

    转: java里poi操作excel的工具类(兼容各版本) 下面是文件内具体内容,文件下载: import java.io.FileNotFoundException; import java.io. ...

  7. “全栈2019”Java第七十九章:类中可以嵌套接口吗?

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  8. Java基础---泛型、集合框架工具类:collections和Arrays

    第一讲     泛型(Generic) 一.概述 1.JDK1.5版本以后出现的新特性.用于解决安全问题,是一个类型安全机制. 2.JDK1.5的集合类希望在定义集合时,明确表明你要向集合中装入那种类 ...

  9. Java数组操作利器:Arrays工具类

    java.util.Arrays提供大量的工具方法来操作数组,这些方法全是静态方法. 1 便捷创建List public static <T> List<T> asList(T ...

随机推荐

  1. Pycharm界面的子窗口不见了,怎么办?

    pycharm程序界面一般有很多子窗口,如图1所示. 图1  Pycharm子窗口 如果你发现某些子窗口不见了,图2是最过分的情形,无须担心. 图2  Pycharm界面的子窗口不见了 打开项目视图子 ...

  2. MySQL数据库(二)事务

    MySQL的存储引擎InnoDB支持事务,MyISAM不支持事物 数据库事务的四大特性(ACID) 原子性(atomic) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,这和前面两篇博客 ...

  3. Linux下新增和使用系统调用

    关键词:__SYSCALL().SYSCALL_DEFINEx().syscall()等等. 1. 为什么使用syscall 内核和用户空间数据交换有很多种方式:sysfs.proc.信号等等. 但是 ...

  4. 关于rabbitmq

    关于rabbitmq 1 简单介绍rabbitmq RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件).RabbitMQ服务器是用Erlang语言编写的,而 ...

  5. 201871010116-祁英红《面向对象程序设计(java)》第十四周学习总结

    博文正文开头格式:(2分) 项目 内容 <面向对象程序设计(java)> https://home.cnblogs.com/u/nwnu-daizh/ 这个作业的要求在哪里 https:/ ...

  6. 201871010112-梁丽珍《面向对象程序设计(java)》第十二周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

  7. 【Oracle】常用函数

    来源自:https://www.cnblogs.com/lxl57610/p/7442130.html Oracle SQL 提供了用于执行特定操作的专用函数.这些函数大大增强了 SQL 语言的功能. ...

  8. 2019 SDN上机第7次作业

    2019 SDN上机第7 次作业 basic补充`/* -- P4_16 -- */ include <core.p4> include <v1model.p4> const ...

  9. C++入门到理解阶段二基础篇(6)——C++数组

    概述 C++ 支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合.数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量. 数组的声明并不是声明一个个单独的变量,比如 numbe ...

  10. 如何在GibHub上传自己的项目

    如何上传项目至GinHub 准备好项目.在项目ssm-crud的目录下右击,点击Git Bash Here,打开git命令行. 在命令行中,输入git init,使项目文件夹加入git管理: 输入gi ...