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

Java.数据结构.HashSet

目录

1 基本概念

2 数据结构

3 常用操作

3.1 add(E e):向HashSet中添加元素

3.2 remove(Object o):从HashSet中移除元素

3.3 contains(Object o):判断HashSet中是否包含指定元素

3.4 size():返回HashSet中元素的个数

3.5 isEmpty():判断HashSet是否为空

 4 优缺点:

5 注意事项


1 基本概念

  • 它只能存储唯一元素,不允许存储重复的元素。
  • HashSet允许存储null值,但只能存储一个null元素

2 数据结构

  • HashSet内部使用HashMap来实现,具体来说是使用一个数组加链表(或红黑树)的方式来存储元素。
  • HashSet根据元素的hashCode值将其分配到不同的桶中,将具有相同hashCode值的元素存储在同一个桶中,然后使用链表(或红黑树)来处理hashCode冲突。

3 常用操作

3.1 add(E e)向HashSet中添加元素
HashSet<String> set = new HashSet<>();  
set.add("apple");  
set.add("banana");

注意add 方法实际上是 boolea 类型 ,如果你要添加的 value 已经存在那么它将添加失败,返回False,反之返回 True,并不会像 HashMap 中的 put 一样后值覆盖前值。

3.2 remove(Object o)从HashSet中移除元素
set.remove("banana");
3.3 contains(Object o)判断HashSet中是否包含指定元素
boolean contains = set.contains("apple");  
System.out.println(contains);  // 输出: true
3.4 size()返回HashSet中元素的个数
int size = set.size();  
System.out.println(size);  // 输出: 1 (假设已移除banana)
3.5 isEmpty()判断HashSet是否为空
boolean isEmpty = set.isEmpty();  
System.out.println(isEmpty);  // 输出: false (假设集合中有元素)

 4 优缺点:

        优点:快速查找(平均时间复杂度为O(1))、高效插入和删除操作

        缺点:非线程安全、不保证顺序

5 注意事项

        HashSet不提供 get()方法来查找集合中指定的元素,但可以使用 contains()方法来判断集合中是否包含指定元素。 

http://www.lryc.cn/news/454183.html

相关文章:

  • 关于懒惰学习与渴求学习的一份介绍
  • sed 环境配置
  • 黑神话:仙童,数据库自动反射魔法棒
  • 香江电器冲刺港交所上市:投资方提前撤资退出,因对赌协议而赔偿
  • SpringSecurity实现自定义登录接口
  • 深度解析:Tkinter 界面布局与优化技巧
  • RCE_无回显
  • 文心一言智能体——绿色生活管家
  • 无人机(自组穿越机,航模)-芯片选型
  • [Cocoa]_[初级]_[绘制文本如何设置断行效果]
  • IPS和IDS有啥区别
  • c基础面试题
  • 选择最佳HR系统_6款产品评测与推荐
  • Latex技巧——参考文献中加入url和doi
  • 安卓WPS Office v18.13.0高级版
  • 【C++力扣】917.仅仅反转字母|387.字符串中第一个唯一字符|415.字符串相加
  • RxSwift系列(四)异常处理和调试操作
  • Excel基础:电子表格Excel的使用技巧合集
  • 教育技术革新:SpringBoot在线教育系统开发
  • 【大数据入门 | Hive】Join语句
  • 爬虫案例——爬取情话网数据
  • 端模一体,猎豹移动对大模型机器人发展路径清晰
  • 操作系统笔记
  • 两个wordpress网站共用一个数据库的数据表
  • 工具方法 - 面试中回答问题的技巧
  • 频繁full gc问题排查及解决
  • 昇思学习打卡营第33天|基于MindSpore的恶性皮肤肿瘤识别
  • 基于SpringBoot+Vue的网约车管理系统
  • Java、PHP、ASP、JSP、Kotlin、.NET、Go
  • 华为-单臂路由