【java数据结构】map和set

【java数据结构】map和set

  • 一、Map和Set的概念以及背景
      • 1.1 概念
      • 1.2 背景
      • 1.3 模型
  • 二、Map
      • 2.1 Map说明
      • 2.2 Map的常用方法
  • 三、Set
      • 3.1 Set说明
      • 3.2 Set的常用方法
  • 四、Set和Map的关系

博客最后附有整篇博客的全部代码!!!

一、Map和Set的概念以及背景

1.1 概念

Map和set是一种专门用来进行搜索的容器或者数据结构,其搜索的效率与其具体的实例化子类有关。

1.2 背景

背景:

到现在为止,当我们要找一个元素的时候,我们可以采取直接遍历的方式,时间复杂度为O(N),或者采用二分查找法,时间复杂度为O(logn),但这两个搜索方式是要求这组序列是有序的!并且这两种方式比较适合静态类型的查找,即一般不会对区间进行插入和删除操作了。
但现实生活中,我们会遇到这类情况:

  1. 根据学生学号找到相应的学生姓名
  2. 通讯录中,根据姓名找到电话
  3. 抖音带货,根据链接号找到相应的商品

这些情况我们在日常生活中经常遇到,并且会实时更新里面的内容,例如删除,修改,即动态查找,此时,二分查找,以及直接遍历,都不适合了。而 Map 和 Set 是一种适合动态查找的集合容器

在这里插入图片描述

1.3 模型

一般把搜索的数据称为关键字(Key),和关键字对应的称为值(Value),将其称之为Key-value的键值对,所以
模型会有两种:

  1. 纯 key 模型,比如:
    有一个英文词典,快速查找一个单词是否在词典中
    快速查找某个名字在不在通讯录中
  2. Key-Value 模型,比如:
    统计文件中每个单词出现的次数,统计结果是每个单词都有与其对应的次数:<单词,单词出现的次数>
    梁山好汉的江湖绰号:每个好汉都有自己的江湖绰号
    而Map中存储的就是key-value的键值对,Set中只存储了Key。

二、Map

2.1 Map说明

Map的官方文档

Map是一个接口类,但是并没有继承Iterable和Collection接口,它的存储方式是Key-Value 模型<K,V>,并且K是唯一值,不能重复

2.2 Map的常用方法

介绍Map接口之前,先给大家讲一下Map.Entry<K, V> ,它是Map的内部类

  • Map.Entry<K, V> 是Map内部实现的用来存放<key, value>键值对映射关系的内部类。
  • 注意:Map.Entry<K,V>并没有提供设置Key的方法

Map.Entry<K, V>提供的方法:
这里主要带你了解 Map.Entry<K, V>提供的前三种方法。
在这里插入图片描述

        /** getKey() 方法* getValue() 方法*/Map<String, Integer> map=new TreeMap<>();map.put("李四",5);map.put("张三",6);map.put("赵六",20);//map.entrySet()将Map集合变为Set集合for (Map.Entry<String, Integer> entry : map.entrySet()) {System.out.println(entry.getKey() + " : " + entry.getValue());}
       /** setValue(V value) 方法*/Map<String, String> map=new TreeMap<>();map.put("key1", "value1");map.put("key2", "value2");String oldValue = map.put("key1", "newValue1");System.out.println("Old Value: " + oldValue); // 输出旧值 value1for (Map.Entry<String, String> entry : map.entrySet()) {System.out.println("Key: " + entry.getKey() +" Value: " + entry.getValue());}}

Map的常用方法:在这里插入图片描述

        Map<String,Integer> map = new TreeMap<>();map.put("A", 1);map.put("B", 2);map.put("C", 3);// get()方法System.out.println(map.get("A"));// getOrDefault()方法System.out.println(map.getOrDefault("D",-1));// remove()方法map.put("D",4);System.out.println(map);map.remove("D");System.out.println(map);// containsKey()方法System.out.println(map.containsKey("A"));//trueSystem.out.println(map.containsKey("D"));///false// containsValue()方法System.out.println(map.containsValue(1));//trueSystem.out.println(map.containsValue(5));//false// keySet()方法获取所有的键Set<String> keys = map.keySet();System.out.println("Keys: " + keys);// values()方法获取所有的值Collection<Integer> values = map.values();System.out.println("Values: " + values);

注意:

  1. Map是一个接口,不能直接实例化对象,如果要实例化对象只能实例化其实现类TreeMap或者HashMap
  2. Map中存放键值对的Key是唯一的,value是可以重复的
  3. Map中的Key可以全部分离出来,存储到Set中来进行访问(因为Key不能重复)。
  4. Map中的value可以全部分离出来,存储在Collection的任何一个子集合中(value可能有重复)。
  5. Map中键值对的Key不能直接修改,value可以修改,如果要修改key,只能先将该key删除掉,然后再来进行重新插入。
  6. 在Map中插入键值对时,key不能为空,否则就会抛NullPointerException异常,但是value可以为空
  1. TreeMap和HashMap的区别
    在这里插入图片描述

三、Set

3.1 Set说明

Set的官方文档

Set是一个接口,它继承了Iterable和Collection接口,它的存储方式是Key 模型,并且K是唯一值,不能重复。

3.2 Set的常用方法

在这里插入图片描述

        Set<String> set = new TreeSet<String>();set.add("A");set.add("B");set.add("C");// contains()方法
//        System.out.println(set.contains("A"));//ture
//        System.out.println(set.contains("D"));//false// remove()方法
//        set.add("E");
//        System.out.println(set);
//        set.remove("E");
//        System.out.println(set);// size()方法
//        System.out.println(set.size());// isEmpty()方法
//        System.out.println(set.isEmpty());// clear()方法
//        System.out.println(set.size());
//        set.clear();
//        System.out.println(set.size());Object[] array = set.toArray();System.out.println("Array from set: " + Arrays.toString(array));// 创建另一个集合Collection<String> collection = Arrays.asList("Banana", "Cherry", "Date");// 使用containsAll()方法检查set是否包含集合中的所有元素boolean containsAll = set.containsAll(collection);System.out.println("是否包含Set集合中所有的元素 " + containsAll);// 使用addAll()方法将集合中的元素添加到set中(可以达到去重的效果)boolean added = set.addAll(collection);System.out.println("将所有元素是否成功添加到set集合中 " + added);System.out.println("添加成功后的集合 " + set);}

注意:

  1. Set是继承自Collection和Iterator的一个接口类,所以它可以通过迭代器打印集合元素
  2. Set中只存储了key,并且要求key一定要唯一
  3. Set的底层是使用Map来实现的,其使用key与Object的一个默认对象作为键值对插入到Map中的
  4. Set最大的功能就是对集合中的元素进行去重
  5. 实现Set接口的常用类有TreeSet和HashSet,还有一个LinkedHashSet,LinkedHashSet是在HashSet的基础上维护了一个双向链表来记录元素的插入次序
  6. Set中的Key不能修改,如果要修改,先将原来的删除掉,然后再重新插入
  7. Set中不能插入null的key。
  1. TreeSet和HashSet的区别:
    在这里插入图片描述

四、Set和Map的关系

  1. HashSet:
  • 底层数据结构是HashMap。
  • 利用HashMap的键来存储元素,由于HashMap的键不允许重复,因此保证了HashSet中元素的唯一性。
  • 不保证元素的顺序。
  1. LinkedHashSet:
  • 底层数据结构是LinkedHashMap。
  • 同样利用LinkedHashMap的键来存储元素,保证了元素的唯一性。
  • 与HashSet相比,LinkedHashSet保持了元素的插入顺序。
  1. TreeSet:
  • 底层数据结构是TreeMap(在Java7及之前)或红黑树(在Java 8及之后)。 利用TreeMap的键来存储元素,通过树形结构保证了元素的有序性。
  • 元素按照自然顺序或构造时指定的比较器(Comparator)排序。
    上述这三种都是通过Map来实现Set的,但并不是所有Set集合都是通过Map来实现的。

在这里插入图片描述
TreeSet底层是通过TreeMap实现的,那add的时候为什么没有value值?
在这里插入图片描述
此篇博客的全部代码!!!

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

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

相关文章

基于迁移学习的ResNet50模型实现石榴病害数据集多分类图片预测

完整源码项目包获取→点击文章末尾名片&#xff01; 番石榴病害数据集 背景描述 番石榴 &#xff08;Psidium guajava&#xff09; 是南亚的主要作物&#xff0c;尤其是在孟加拉国。它富含维生素 C 和纤维&#xff0c;支持区域经济和营养。不幸的是&#xff0c;番石榴生产受到降…

企业信息化2:行政办公管理系统

总裁办公室作为综合行政管理部门服务于整个公司&#xff0c;工作职责包含从最基础的行政综合到协调督办、对外政务、品牌建设等等&#xff0c;工作量繁多而且琐碎。如何通过信息化来实现标准化和常态化的管理手段&#xff0c;确保总裁办的各项工作有章可循&#xff0c;提高工作…

基于springboot+vue的古城景区管理系统的设计与实现

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

使用 Elasticsearch 导航检索增强生成图表

作者&#xff1a;来自 Elastic Louis Jourdain 及 Ivan Monnier 了解如何使用知识图谱来增强 RAG 结果&#xff0c;同时在 Elasticsearch 中高效存储图谱。本指南探讨了根据用户查询动态生成知识子图的详细策略。 检索增强生成 (RAG) 通过将大型语言模型 (LLM) 的输出基于事实数…

【数据结构】_以SLTPushBack(尾插)为例理解单链表的二级指针传参

目录 1. 第一版代码 2. 第二版代码 3. 第三版代码 前文已介绍无头单向不循环链表的实现&#xff0c;详见下文&#xff1a; 【数据结构】_不带头非循环单向链表-CSDN博客 但对于部分方法如尾插、头插、任意位置前插入、任意位置前删除的相关实现&#xff0c;其形参均采用了…

ceph新增节点,OSD设备,标签管理(二)

一、访问客户端集群方式 方式一: 使用cephadm shell交互式配置 [rootceph141 ~]# cephadm shell # 注意&#xff0c;此命令会启动一个新的容器&#xff0c;运行玩后会退出&#xff01; Inferring fsid c153209c-d8a0-11ef-a0ed-bdb84668ed01 Inferring config /var/lib/ce…

Spring Data JPA 实战:构建高性能数据访问层

1 简介 1.1 Spring Data JPA 概述 1.1.1 什么是 Spring Data JPA? Spring Data JPA 是 Spring Data 项目的一部分,旨在简化对基于 JPA 的数据库访问操作。它通过提供一致的编程模型和接口,使得开发者可以更轻松地与关系型数据库进行交互,同时减少了样板代码的编写。Spri…

Git进阶笔记系列(01)Git核心架构原理 | 常用命令实战集合

读书笔记&#xff1a;卓越强迫症强大恐惧症&#xff0c;在亲子家庭、职场关系里尤其是纵向关系模型里&#xff0c;这两种状态很容易无缝衔接。尤其父母对子女、领导对下属&#xff0c;都有望子成龙、强将无弱兵的期望&#xff0c;然而在你的面前&#xff0c;他们才是永远强大的…

基于模糊PID的孵化箱温度控制系统(论文+源码)

1系统方案设计 本课题为基于模糊PID的孵化箱温度控制系统&#xff0c;其以STM32最小系统与模糊PID控制器为控制核心。系统主要包括数据采集模块、处理器模块、电机控制模块。 数据采集模块由温度传感器构成&#xff0c;通过温度传感器感应温度变化&#xff0c;获得待处理的数据…

Arcgis国产化替代:Bigemap Pro正式发布

在数字化时代&#xff0c;数据如同新时代的石油&#xff0c;蕴含着巨大的价值。从商业决策到科研探索&#xff0c;从城市规划到环境监测&#xff0c;海量数据的高效处理、精准分析与直观可视化&#xff0c;已成为各行业突破发展瓶颈、实现转型升级的关键所在。历经十年精心打磨…

ThreeJS示例教程200+【目录】

Three.js 是一个强大的 JavaScript 库,旨在简化在网页上创建和展示3D图形的过程。它基于 WebGL 技术,但提供了比直接使用 WebGL 更易于使用的API,使得开发者无需深入了解 WebGL 的复杂细节就能创建出高质量的3D内容。 由于目前内容还不多,下面的内容暂时做一个占位。 文章目…

opengrok_使用技巧

Searchhttps://xrefandroid.com/android-15.0.0_r1/https://xrefandroid.com/android-15.0.0_r1/ 选择搜索的目录&#xff08;工程&#xff09; 手动在下拉框中选择&#xff0c;或者 使用下面三个快捷按钮进行选择或者取消选择。 输入搜索的条件 搜索域说明 域 fullSearc…

无人机如何自主侦察?UEAVAD:基于视觉的无人机主动目标探测与导航数据集

作者&#xff1a;Xinhua Jiang, Tianpeng Liu, Li Liu, Zhen Liu, and Yongxiang Liu 单位&#xff1a;国防科技大学电子科学学院 论文标题&#xff1a;UEVAVD: A Dataset for Developing UAV’s Eye View Active Object Detection 论文链接&#xff1a;https://arxiv.org/p…

【图文详解】lnmp架构搭建Discuz论坛

安装部署LNMP 系统及软件版本信息 软件名称版本nginx1.24.0mysql5.7.41php5.6.27安装nginx 我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客: 关闭防火墙 systemctl stop firewalld &&a…

Ansible入门学习之基础元素介绍

一、Ansible目录结构介绍 1.通过rpm -ql ansible获取ansible所有文件存放的目录 有配置文件目录 /etc/ansible/ 执行文件目录 /usr/bin/ 其中 /etc/ansible/ 该文件目录的主要功能是 inventory主机信息配置&#xff0c;ansible工具功能配置。 ansible自身的配置文件…

git Bash通过SSH key 登录github的详细步骤

1 问题 通过在windows 终端中的通过git登录github 不再是通过密码登录了&#xff0c;需要本地生成一个密钥&#xff0c;配置到gihub中才能使用 2 步骤 &#xff08;1&#xff09;首先配置用户名和邮箱 git config --global user.name "用户名"git config --global…

矩阵的秩在机器学习中具有广泛的应用

矩阵的秩在机器学习中具有广泛的应用&#xff0c;主要体现在以下几个方面&#xff1a; 一、数据降维与特征提取 主成分分析&#xff08;PCA&#xff09;&#xff1a; PCA是一种常用的数据降维技术&#xff0c;它通过寻找数据中的主成分&#xff08;即最大方差方向&#xff09…

Windows Defender添加排除项无权限的解决方法

目录 起因Windows Defender添加排除项无权限通过管理员终端添加排除项管理员身份运行打开PowerShell添加/移除排除项的命令 起因 博主在打软件补丁时&#xff0c;遇到 Windows Defender 一直拦截并删除文件&#xff0c;而在 Windows Defender 中无权限访问排除项。尝试通过管理…

IDEA工具下载、配置和Tomcat配置

1. IDEA工具下载、配置 1.1. IDEA工具下载 1.1.1. 下载方式一 官方地址下载 1.1.2. 下载方式二 官方地址下载&#xff1a;https://www.jetbrains.com/idea/ 1.1.3. 注册账户 官网地址&#xff1a;https://account.jetbrains.com/login 1.1.4. JetBrains官方账号注册…

计算机网络之应用层

本文章目录结构出自于《王道计算机考研 计算机网络_哔哩哔哩_bilibili》 05 应用层 在网上看到其他人做了相关笔记&#xff0c;就不再多余写了&#xff0c;直接参考着学习吧。 王道考研 计算机网络笔记 第六章&#xff1a;应用层_王道考研 应用层 笔记-CSDN博客 DNS&#x…