当前位置: 首页 > news >正文

集合框架14:TreeSet概述、TreeSet使用、Comparator接口及举例

视频链接:13.29 TreeSet概述_哔哩哔哩_bilibiliicon-default.png?t=O83Ahttps://www.bilibili.com/video/BV1zD4y1Q7Fw?spm_id_from=333.788.videopod.episodes&vd_source=b5775c3a4ea16a5306db9c7c1c1486b5&p=29

1、TreeSet概述

  • 基于排列顺序实现元素不重复;
  • 实现了SortedSet接口,对元素集合自动排序;
  • 元素的接口必须实现Comparable接口,指定排序规则;
  • 通过comparaTo 方法确定元素是否为重复;

2.TreeSet添加基本类型元素使用举例

package com.yundait.demo02;import java.util.Iterator;
import java.util.TreeSet;public class TreeSetDemo01 {public static void main(String[] args) {//创建TreeSet集合TreeSet<String> strings = new TreeSet<>();//1添加元素strings.add("xyz");strings.add("abc");strings.add("beijing");//strings.add("xyz");//不能添加重复元素System.out.println(strings.size());System.out.println(strings.toString());//2删除元素//strings.remove("xyz");System.out.println(strings.size());//3遍历集合元素for (String string : strings) {System.out.println(string);}System.out.println("-----------------");Iterator<String> iterator = strings.iterator();while (iterator.hasNext()){System.out.println(iterator.next());}//4判断System.out.println("-----------------");System.out.println(strings.contains("beijing"));System.out.println(strings.isEmpty());}
}

3.TreeSet集合添加引用类型元素举例

package com.yundait.demo02;import java.util.Iterator;
import java.util.TreeSet;/**** 使用TreeSet保存数据*村存储结构:红黑树;* 要求:元素必须要实现Comparable接口,当compareTo方法返回值为0,则认为是重复元素;*/public class TreeSetDemo02 {public static void main(String[] args) {//创建集合TreeSet<Person> people = new TreeSet<>();//1添加元素Person p1 = new Person("abc", 20);Person p2 = new Person("xyz", 20);Person p3 = new Person("nanjing", 20);Person p4 = new Person("nanjing", 19);Person p5 = new Person("nanjing", 19);people.add(p1);people.add(p2);people.add(p3);people.add(p4);people.add(p5);//因为compareTo方法返回值为0,认为是重复元素,不能添加System.out.println("集合元素的个数为:" + people.size());System.out.println(people.toString());//2删除元素//people.remove(p1);//people.remove(new Person("abc",20));//因为重写了comparable方法,所以以上两种删除方式都可以实现;System.out.println(people.toString());System.out.println("删除后元素的个数为:" + people.size() );//3遍历集合//3.1使用增强for循环for(Person person : people){System.out.println(person);}//3.2使用迭代器System.out.println("---------------------");Iterator<Person> iterator = people.iterator();while (iterator.hasNext()){System.out.println(iterator.next());}//4判断System.out.println(people.isEmpty());System.out.println(people.contains(new Person("nanjing", 19)));}
}

想要添加成功元素需要实现Comparable接口,重写接口中的compareTo 方法

public class Person implements Comparable<Person> {//元素实现Comparable接口private String name;private int age;public Person() {}public Person(String name, int age) {this.name = name;this.age = age;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}@Overridepublic String toString() {return "Person{" +"name='" + name + '\'' +", age=" + age +'}';}@Overridepublic boolean equals(Object o) {if (this == o) return true;if (!(o instanceof Person)) return false;Person person = (Person) o;return getAge() == person.getAge() && Objects.equals(getName(), person.getName());}@Overridepublic int hashCode() {return Objects.hash(getName(), getAge());}@Override//重写comparaTo方法public int compareTo(Person o) {int n1 = this.getName().compareTo(o.getName());int n2 = this.age - o.age;return n1 == 0 ? n2 : n1;}
}

4.Comparator接口

package com.yundait.demo02;import java.util.Comparator;
import java.util.TreeSet;public class TreeSetDemo03 {public static void main(String[] args) {TreeSet<Person> people = new TreeSet<>(new Comparator<Person>() {//创建集合时,使用匿名内部类实现Comparator接口重写接口中的compare方法,自定义比较规则@Overridepublic int compare(Person o1, Person o2) {int n1 = o1.getAge() - o2.getAge();int n2 = o1.getName().compareTo(o2.getName());return n1 == 0 ? n2 : n1;}});Person p1 = new Person("abc", 28);Person p2 = new Person("xyz", 15);Person p3 = new Person("nanjing", 29);Person p4 = new Person("nanjing", 15);people.add(p1);people.add(p2);people.add(p3);people.add(p4);System.out.println(people.toString());}
}

5.小案例

/*** 案例需求:使用TreeSet集合实现字符串元素按照长度进行排序* Comparator接口实现比较;*/
public class TreeSetDemo04 {public static void main(String[] args) {TreeSet<String> strings = new TreeSet<>(new Comparator<String>() {@Overridepublic int compare(String o1, String o2) {int n1 = o1.length() - o2.length();int n2 = o1.compareTo(o2);return n1==0?n2:n1;}});strings.add("HelloWorld");strings.add("pingguo");strings.add("lisi");strings.add("zhangsan");strings.add("beijing");strings.add("cat");strings.add("nanjing");strings.add("xian");System.out.println(strings.toString());}
}

相关文章:

集合框架14:TreeSet概述、TreeSet使用、Comparator接口及举例

视频链接&#xff1a;13.29 TreeSet概述_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1zD4y1Q7Fw?spm_id_from333.788.videopod.episodes&vd_sourceb5775c3a4ea16a5306db9c7c1c1486b5&p29 1、TreeSet概述 基于排列顺序实现元素不重复&#xff1b;实现了Sort…...

uniapp获取底部导航tabbar的高度(H5)

uniapp获取底部导航tabbar的高度&#xff08;H5&#xff09; <view :style"bottom: tabBarHeight px;"> </view>tabBarHeight: 0, // 底部tabBar高度&#xff0c; h5// #ifdef H5 getTabBarHeight(){const systemInfo uni.getSystemInfoSync()this.t…...

接口测试 —— 如何测试加密接口?

接口加密是指在网络传输过程中&#xff0c;将数据进行加密&#xff0c;以保护数据的安全性。接口加密可以采用多种加密算法&#xff0c;如AES、DES、RSA等。测试接口加密的目的是验证接口加密算法的正确性和安全性。以下是一些详细的测试方法和注意事项&#xff1a; 接口加密字…...

033 商品搜索

文章目录 SearchController.javaPage.javaSpuInfoServiceImpl.javaSpuInfoService.javaCubemallSearchApplication.javasearch.htmlpom.xml 功能分析 页面回显的数据&#xff1a; searchMap keywords&#xff1a;搜索的关键词 brand&#xff1a;过滤条件-品牌 category&…...

身份证二要素实名认证接口-身份证核验接口-身份证实名API

接口简介&#xff1a;企业三要素验证&#xff0c;输入公司名称、统一社会信用代码、法人姓名验证是否一致 接口地址&#xff1a;https://www.wapi.cn/api_detail/62/169.html 在线核验&#xff1a;https://www.wapi.cn/icardauth.html 网站地址&#xff1a;https://www.wapi.cn…...

一次恶意程序分析

首先F12shift查看字符表 字符表发现可疑字符串 双击进入 再tab 进入这里 推测为main函数 可见一些可疑的api FindResourceW推测该木马使用了资源加载 VirtualAlloc申请内存 然后sub_1400796E0 有 dwSize 参数 推测为 拷贝内存 memcpy类似函数 、 然后sub_140078CB0函数 跟进函…...

Javaweb基础-vue

Vue.js Vue是一套用于构建用户界面的渐进式框架。 起步 引入vue <head><script src"static/js/vue2.6.12.min.js"></script> </head> 创建vue应用 <body> <div id"index"><p>{{message}}</p> </div>…...

2. MySQL数据库基础

一、数据库的操作 1. 显示当前的数据库 SHOW DATABASES;2. 创建数据库 语法&#xff1a; CREATE DATABASE [IF NOT EXISTS] db_name [create_specification...];//create_specification包括&#xff1a;[DEFAULT] CHARACTER SET charset_name[DEFAULT] COLLATE collation_n…...

java集合进阶篇-《泛型》

个人主页→VON 收录专栏→java从入门到起飞 目录 一、前言 二、泛型的简要概述 三、泛型的基本概念 类型参数&#xff1a; 通配符&#xff1a; 边界&#xff1a; 使用泛型的好处&#xff1a; 四、泛型类 五、泛型方法 六、思考 七、疑惑 一、前言 泛型对于我来说又…...

pytorh学习笔记——cifar10(三)模仿VGGNet创建卷积网络

VGG16是由牛津大学视觉几何组&#xff08;Visual Geometry Group&#xff09;提出的一种深度卷积神经网络模型。 VGGNet 探索了卷积神经网络的深度与其性能之间的关系&#xff0c;成功地构筑了 16~19 层深的卷积神经网络&#xff0c;同时拓展性又很强&#xff0c;迁移到其它图片…...

题目:连续子序列

解题思路&#xff1a; 首先&#xff0c;不能使用暴力枚举&#xff0c;时间为O(n2)&#xff0c;超时。以下为正确做法&#xff1a; 假设找到一段区间&#xff08;其和>m&#xff09;&#xff0c;如上图黄色部分&#xff0c;那么该区间加上i后面的元素形成的新区间和都>m&a…...

深入解析:Nacos AP 模式的实现原理与应用场景

优质博文&#xff1a;IT-BLOG-CN 一、CAP 基础 ‌Nacos作为注册中心同时支持CP和AP模式。‌ Nacos通过不同的协议和机制来实现这两种模式&#xff0c;以满足不同的需求场景。 在Nacos中&#xff0c;默认情况下使用的是AP模式&#xff0c;通过Distro协议来实现。AP模式主要关…...

snmpnetstat使用说明

1.snmpnetstat介绍 snmpnetstat命令是用来查看snmp服务器的端口连接信息。 2.snmpnetstat安装 1.snmpnetstat安装 命令: yum -y install net-snmp net-snmp-utils [root@logstash ~]# yum -y install net-snmp net-snmp-utils Loaded plugins: fastestmirror Loading mi…...

linux线程 | 同步与互斥 | 互斥(下)

前言&#xff1a;本篇文章主要讲述linux线程的互斥的知识。 讲解流程为先讲解锁的工作原理&#xff0c; 再自己封装一下锁并且使用一下。 做完这些就要输出一堆理论性的东西&#xff0c; 但博主会总结两条结论&#xff01;&#xff01;最后就是讲一下死锁。 那么&#xff0c; 废…...

2024-10-17 问AI: [AI面试题] 讨论 AI 的挑战和局限性

文心一言 AI&#xff08;人工智能&#xff09;虽然取得了显著的进步&#xff0c;但仍面临多方面的挑战和局限性。以下是对AI挑战和局限性的详细讨论&#xff1a; 一、数据质量与可靠性 数据质量&#xff1a;AI系统依赖于高质量的数据进行训练和学习。如果数据质量低劣或包含…...

go基础(一)

包声明引入包函数变量语句&表达式注释 package main//包声明import "fmt"//引入包 //函数 func main() {/* 这是我的第一个简单的程序 */fmt.Println("Hello, World!") }基础语法 标记 go程序可以由多个标记组成&#xff0c;可以是关键字&#xff0…...

python忽略warnings 的方法

我在训练深度学习模型的时候一直出现这样的警告&#xff0c;但是不影响运行&#xff1a; UserWarning: Failed to load image Python extension: [WinError 127] 找不到指定的程序。 warn(f"Failed to load image Python extension: {e}") 要避免在 Python 程序运…...

2024年底蓝奏云最新可用API接口列表 支持优享版 无需手动抓取cookie

Lanzou Pro V1 接口列表 API状态版本路由获取文件与目录✅^1.0.1/v1/getFilesAndDirectories?url{}&page{}获取目录✅^1.0.0/v1/getDirectory?url{}获取文件✅^1.0.1/v1/getFiles?url{}&page{}搜索文件✅^1.0.0/v1/searchFile?url{}&wd{}依Id解析✅^1.0.2/v1/…...

Linux常用命令详细解析(含完整命令演示过程)

目录 1. 目录结构介绍 2. Linux命令基础 2.1 命令和命令行 2.2 格式 3. 常用命令 3.1 产看目录命令——ls 3.2 通配符 3.3 改变工作目录命令——cd 3.4 查看当前路径命令——pwd 3.5 创建新的目录命令——mkdir 3.6 创建文件目录命令——touch 3.7 查看…...

《使用Gin框架构建分布式应用》阅读笔记:p101-p107

《用Gin框架构建分布式应用》学习第7天&#xff0c;p101-p107总结&#xff0c;总计7页。 一、技术总结 1.StatusBadRequest vs StatusInternalServerError 写代码的时候有一个问题&#xff0c;什么时候使用 StatusBadRequest(400错误)&#xff0c;什么时候使用 StatusIntern…...

Starry Night Art Gallery实战案例:小红书爆款插画AI生成流程

Starry Night Art Gallery实战案例&#xff1a;小红书爆款插画AI生成流程 1. 引言&#xff1a;当AI艺术遇上小红书爆款 如果你在小红书上刷到过那些点赞过万、充满梦幻色彩的插画作品&#xff0c;可能会好奇&#xff1a;这些画风独特、细节精美的作品&#xff0c;到底是怎么创…...

5种手柄映射方案让手游玩家实现主机级操控体验

5种手柄映射方案让手游玩家实现主机级操控体验 【免费下载链接】escrcpy &#x1f4f1; Display and control your Android device graphically with scrcpy. 项目地址: https://gitcode.com/GitHub_Trending/es/escrcpy 手机游戏操控优化一直是困扰玩家的核心痛点&…...

Instructions终极指南:5个简单步骤创建你的第一个iOS引导标记

Instructions终极指南&#xff1a;5个简单步骤创建你的第一个iOS引导标记 【免费下载链接】Instructions Create walkthroughs and guided tours (coach marks) in a simple way, with Swift. 项目地址: https://gitcode.com/gh_mirrors/in/Instructions Instructions是…...

3MF插件全解析:Blender如何成为3D打印的得力助手?

3MF插件全解析&#xff1a;Blender如何成为3D打印的得力助手&#xff1f; 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 还在为Blender中无法处理3MF文件而烦恼吗&#…...

PyG实战:用自定义MessagePassing为异构图构建一个简单的推荐系统消息传递层

PyG实战&#xff1a;构建异构图的推荐系统消息传递层 当我们在电商平台上浏览商品时&#xff0c;系统总能精准推荐我们可能感兴趣的内容。这背后往往隐藏着一个复杂的用户-商品交互网络&#xff0c;而图神经网络(GNN)正是处理这类异构关系的利器。今天&#xff0c;我们就来探索…...

CentOS 7 服务器环境部署 Pixel Dream Workshop:针对企业级生产的配置

CentOS 7 服务器环境部署 Pixel Dream Workshop&#xff1a;针对企业级生产的配置 1. 前言&#xff1a;为什么选择这个方案 如果你正在寻找一个稳定可靠的企业级AI图像生成解决方案&#xff0c;Pixel Dream Workshop在CentOS 7上的部署可能是你的理想选择。作为运维工程师&am…...

interactive-deep-colorization与Adobe Photoshop Elements对比分析:免费AI上色工具如何超越专业软件?

interactive-deep-colorization与Adobe Photoshop Elements对比分析&#xff1a;免费AI上色工具如何超越专业软件&#xff1f; 【免费下载链接】interactive-deep-colorization Deep learning software for colorizing black and white images with a few clicks. 项目地址: …...

Intv_AI_MK11 架构设计咨询:后端微服务拆分与通信方案评估

Intv_AI_MK11 架构设计咨询&#xff1a;后端微服务拆分与通信方案评估 1. 微服务架构的核心挑战 想象你正在设计一个电商平台的后端系统。随着业务增长&#xff0c;单体架构开始暴露出各种问题&#xff1a;部署周期长、扩展困难、技术栈单一。这时微服务架构自然成为解决方案…...

论文精读|AOrchestra:让编排器自动「按需创建」专属子智能体的 Agentic 框架

这篇论文来自 HKUST(GZ)&#xff08;香港科技大学广州&#xff09;和 DeepWisdom&#xff0c;联合 RUC、ECNU、UdeM & Mila 等多所院校&#xff0c;发表于 2026 年 2 月的 arXiv 预印本。论文题为 “AOrchestra: Automating Sub-Agent Creation for Agentic Orchestration”…...

SEO 舆情处理中数据分析的作用是什么

SEO 舆情处理中数据分析的作用 在当今数字化社会&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;和舆情处理已经成为企业品牌管理的重要组成部分。尤其是在网络信息迅速传播的今天&#xff0c;舆情的好坏直接影响到企业的声誉和市场竞争力。因此&#xff0c;如何有效地进…...