treeset的用法,和其中的比较器(比较字符串)

本文通过示例展示了如何在Java中使用TreeSet结合自定义Comparator实现字符串按长度及字典顺序排序。首先创建了一个TreeSet按默认方式排序字符串,然后通过自定义Comparator实现了按字符串长度进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在完成代码时候当用到if语句的时候,使用了更加简便的代码。

import java.util.Comparator;
import java.util.TreeSet;

class CompareLengt extends Object implements Comparator<String>{
    public int compare(String o1,String o2){
    int Lenght = o1.length() - o2.length();
    return Lenght == 0 ? o1.compareTo(o2) : Lenght;
    }
}

public class Test3 {
    public static void main(String[] args) {
        //使用treeset打印时会比较里面的内容
        TreeSet<String> ts1 = new TreeSet<String>();
        ts1.add("aaaaaaaaaaaaaa");
        ts1.add("woshi");
        ts1.add("abc");
        ts1.add("c");
        System.out.println(ts1);
        //使用比较器,让他比较长度
        TreeSet<String> ts2 = new TreeSet<String>(new CompareLengt());
        ts2.add("aaaaaaaaaaaaaa");
        ts2.add("woshi");
        ts2.add("abc");
        ts2.add("c");
        System.out.println(ts2);

    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值