TreeMap 和 TreeSet 的基本情况、特性以及使用场景,并对比它们与 HashMap 和 HashSet

TreeMap

基本情况

  • 实现:基于红黑树实现的 NavigableMap
  • 排序:键按自然顺序或自定义顺序(通过 Comparator)排序。
  • 特性
    • 不允许 null 键,但允许 null 值。
    • 保证键有序。
    • 迭代时按排序顺序。
    • 复杂度:基本操作如 putgetremove 复杂度为 O(log n)。

使用场景

  • 需要按键有序的映射。
  • 需要快速查找范围查询(如获取某区间的键值对)。
  • 需要按排序顺序迭代键值对。

TreeSet

基本情况

  • 实现:基于 TreeMap 实现。
  • 排序:元素按自然顺序或自定义顺序(通过 Comparator)排序。
  • 特性
    • 不允许 null 元素。
    • 保证元素有序。
    • 迭代时按排序顺序。
    • 复杂度:基本操作如 addremovecontains 复杂度为 O(log n)。

使用场景

  • 需要保持元素有序的集合。
  • 需要快速查找范围查询(如获取某区间的元素)。
  • 需要按排序顺序迭代。

HashMap

基本情况

  • 实现:基于哈希表实现的 Map
  • 排序:无序。
  • 特性
    • 允许 null 键和 null 值。
    • 不保证顺序,元素顺序可能随时间变化。
    • 复杂度:基本操作如 putgetremove 复杂度为 O(1)。

使用场景

  • 需要快速查找、插入和删除的映射。
  • 不关心元素顺序。

HashSet

基本情况

  • 实现:基于 HashMap 实现。
  • 排序:无序。
  • 特性
    • 允许 null 元素。
    • 不保证顺序,元素顺序可能随时间变化。
    • 复杂度:基本操作如 addremovecontains 复杂度为 O(1)。

使用场景

  • 需要快速查找、插入和删除的集合。
  • 不关心元素顺序。

比较与对比

相同点

  • TreeSetTreeMap

    • 都基于红黑树实现,保证元素/键有序。
    • 复杂度相同:基本操作复杂度为 O(log n)。
  • HashSetHashMap

    • 都基于哈希表实现,不保证元素/键有序。
    • 复杂度相同:基本操作复杂度为 O(1)。

不同点

  • 有序 vs 无序

    • TreeSetTreeMap 保证元素/键有序。
    • HashSetHashMap 不保证元素/键有序。
  • 允许 null 的情况

    • TreeSet 不允许 null 元素。
    • TreeMap 不允许 null 键,但允许 null 值。
    • HashSet 允许 null 元素。
    • HashMap 允许 null 键和 null 值。
  • 使用场景

    • TreeSetTreeMap 适用于需要排序的场景,且支持范围查询
    • HashSetHashMap 适用于需要快速查找、插入和删除的场景,不关心元素顺序

总结

选择 TreeSetTreeMapHashSetHashMap 取决于具体需求:

  • 需要有序集合/映射,范围查询:选择 TreeSetTreeMap
  • 需要快速查找、插入和删除,无序要求:选择 HashSetHashMap

理解各自的特性和使用场景,能够更高效地解决问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/38196.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【最长公共前缀 动态规划】2430. 对字母串可执行的最大删除数

如果有不明白的,请加文末QQ群。 本文涉及知识点 最长公共前缀 动态规划 动态规划汇总 LeetCode 2430. 对字母串可执行的最大删除数 给你一个仅由小写英文字母组成的字符串 s 。在一步操作中,你可以: 删除 整个字符串 s ,或者 …

vscode中的字符缩进问题

问题描述: 如图当一行代码中出现不同类型的字符时,使用tab缩只是插入了固定数量(默认4)的空格或制表符,仍然无法对齐。 解决方法: vscode找到设置,搜索fontFamily,对应输入框写入mon…

Linux系统编程--进程间通信

目录 1. 介绍 1.1 进程间通信的目的 1.2 进程间通信的分类 2. 管道 2.1 什么是管道 2.2 匿名管道 2.2.1 接口 2.2.2 步骤--以父子进程通信为例 2.2.3 站在文件描述符角度-深度理解 2.2.4 管道代码 2.2.5 读写特征 2.2.6 管道特征 2.3 命名管道 2.3.1 接口 2.3.2…

集成平台建设方案(Doc原件)

基础支撑平台作为系统总体架构的核心,不仅要促进与各应用子系统和第三方系统的顺畅交互,还需确保内部业务在该平台上能够灵活扩展。针对这一需求,我们对基础支撑平台提出了以下要求: (1) 平台需基于其基础架构,为多源异…

python基础:设置代码格式

随着编写的程序越来越长,有必要了解一些代码格式的约定,让你的代码尽可以能易于阅读。 python代码编写规范为PEP8,有兴趣的朋友可以下载观看,这里仅作简要说明。 1、缩进 PEP8建议每级缩进都使用4个空格。多数情况下编程语言的…

vscode-创建vue3项目-修改暗黑主题-常见错误-element插件标签-用法涉及问题

文章目录 1.vscode创建运行编译vue3项目2.添加项目资源3.添加element-plus元素4.修改为暗黑主题4.1.在main.js主文件中引入暗黑样式4.2.添加自定义样式文件4.3.html页面html标签添加样式 5.常见错误5.1.未使用变量5.2.关闭typescript检查5.3.调试器支持5.4.允许未到达代码和未定…

UE5的安装与基本操作(一)

文章目录 前言安装UE5新建第一个游戏项目基本游览方式对目标进行变换各种变换对齐 快速定位目标 总结 前言 Unreal Engine 5 (UE5) 是一款由 Epic Games 开发的实时 3D 创作平台,用于制作游戏、电影、动画、建筑可视化和其他类型的交互式体验。UE5 提供了一系列强大…

Flutter第十五弹 Flutter插件

目标: 1.Flutter插件是什么?有什么作用? 插件 (plugin) 是 package 的一种,全称是 plugin package,我们简称为 plugin,中文叫插件。 2.怎么创建Flutter插件? 一、什么是插件 在flutter中&am…

【成都活动邀请函】7月6 | PowerData 数字经济-“成都“开源行!

【成都活动邀请函】7月6 | PowerData 数字经济-"成都"开源行! 活动介绍活动信息线上直播扫码报名往期活动回顾专注数据开源,推动大数据发展 活动介绍 九天开出一成都,万户千门入画图。 自古以来,成都便是国家发展的重要…

第2章-Python编程基础

#本章目标 1,了解什么是计算机程序 2,了解什么是编程语言 3,了解编程语言的分类 4,了解静态语言与脚本语言的区别 5,掌握IPO程序编写方法 6,熟练应用输出函数print与输入函数input 7,掌握Python…

【机器学习】机器学习的重要技术——生成对抗网络:理论、算法与实践

引言 生成对抗网络(Generative Adversarial Networks, GANs)由Ian Goodfellow等人在2014年提出,通过生成器和判别器两个神经网络的对抗训练,成功实现了高质量数据的生成。GANs在图像生成、数据增强、风格迁移等领域取得了显著成果…

leetCode.97. 交错字符串

leetCode.97. 交错字符串 题目思路 代码 class Solution { public:bool isInterleave(string s1, string s2, string s3) {int n s1.size(), m s2.size();if ( s3.size() ! n m ) return false;vector<vector<bool>> f( n 1, vector<bool> (m 1));s1 …

C语言使用void *类型作为函数传参

C语言使用void *怎么理解&#xff1a; 根据本人的理解&#xff0c;他就是指向操作数据区的首地址而已 凡是void指的数据区都要进行第二次初始化数据类型&#xff08;即dtype p(dtype)pdata&#xff09;*。 举两个例子&#xff1a; 传入函数&#xff1a; void tx_data(void …

Sparse4D v3: Advancing End-to-End 3D Detection and Tracking

Sparse4D v3: Advancing End-to-End 3D Detection and Tracking 相关内容&#xff1a;总览&#xff0c;Sparse4D v1&#xff0c;Sparse4D v2&#xff0c; 单位&#xff1a;地平线(Sparse4D v1 v2 原班人马) GitHub&#xff1a;https://github.com/HorizonRobotics/Sparse4D …

昇思25天学习打卡营第5天 | 网络构建

目录 1.定义模型类 2.模型层 nn.Flatten nn.Dense nn.ReLU nn.SequentialCell nn.Softmax 3.模型参数 代码实现&#xff1a; 总结 神经网络模型是由神经网络层和Tensor操作构成的&#xff0c; mindspore.nn提供了常见神经网络层的实现&#xff0c; 在MindSpore中&a…

启动spring boot项目停止 提示80端口已经被占用

可能的情况: 检查并结束占用进程: 首先,你需要确定哪个进程正在使用80端口。在Windows上,可以通过命令行输入netstat -ano | findstr LISTENING | findstr :80来查看80端口的PID,然后在任务管理器中结束该进程。在

AI智能客服项目拆解(1) 产品大纲

本文作为拆解AI智能客服项目的首篇&#xff0c;以介绍产品大纲为主。后续以某AI智能客服产品为例&#xff0c;拆解相关技术细节。 AI智能客服是一种基于人工智能技术的客户服务解决方案&#xff0c;旨在提高客户满意度和优化企业运营。利用人工智能和自然语言处理技术&#xff…

MySQL之索引失效的情况

什么情况下索引会失效&#xff1f; 违反最左前缀原则范围查询右边的列不能使用索引不要在索引列上进行运算操作字符串不加单引号导致索引失效以%开头的like模糊查询 什么情况下索引会失效&#xff1f; 示例&#xff0c;有user表如下 CREATE TABLE user (id bigint(20) NOT NU…

实验1 多层感知器设计(MLP)

1.实验目的 掌握多层感知器的原理。掌握多层感知器的设计、训练和测试。2.实验要求 设计一个多层感知器,用于对给定的数据进行分类。要求代码格式规范,注释齐全,程序可正常运行。 3.模型设计 实验设计一个多层感知机,三层机构,只含一个隐藏层,输入层,隐藏层,输出层 1…

JAVA期末速成库(11)第十二章

一、习题介绍 第十二章 Check Point&#xff1a;P454 12.1&#xff0c;12.9&#xff0c;12.10&#xff0c;12,12 二、习题及答案 12.1 What is the advantage of using exception handling? 12.1使用异常处理的优势是什么? 答:使用异常处理有以下优势&#xff1a; 1. 提高…