探索集合python(Set)的神秘面纱:它与字典有何不同?

 

 新书上架~👇全国包邮奥~

python实用小工具开发教程icon-default.png?t=N7T8http://pythontoolsteach.com/3

 欢迎关注我👆,收藏下次不迷路┗|`O′|┛ 嗷~~

目录

一、集合(Set)与字典(Dictionary)的初识

1. 集合的无序性

2. 集合的唯一性

二、集合的内部实现原理

1. 哈希函数的作用

2. 冲突解决

三、集合的使用场景与示例

1. 去除重复元素

2. 交集、并集和差集运算


一、集合(Set)与字典(Dictionary)的初识

    在编程的世界里,字典和集合都是常见的数据结构,但它们的用途和特点却大不相同。就像字典为我们提供了键值对的存储方式,集合则以其独特的无序性和唯一性著称。

1. 集合的无序性

    与字典不同,集合并不保证元素的顺序。这意味着,当你向集合中添加元素时,这些元素在集合中的位置可能会因各种因素而改变。但正是这种无序性,使得集合在处理一些不需要特定顺序的场景时,表现出更高的效率。

2. 集合的唯一性

    集合的另一个显著特点是元素的唯一性。在集合中,每个元素只能出现一次。这意味着,如果你尝试向集合中添加一个已经存在的元素,该操作将被忽略。这种特性使得集合在去除重复元素时非常有用。

二、集合的内部实现原理

    集合和字典在内部实现上都依赖于哈希表(Hash Table)。哈希表是一种通过哈希函数将键(Key)映射到值(Value)的数据结构。在集合中,哈希函数被用来将元素映射到存储位置,从而实现快速的查找和插入操作。

1. 哈希函数的作用

    哈希函数在集合中起着至关重要的作用。它通过计算元素的哈希值,将元素映射到哈希表的特定位置。这样,当需要查找或插入元素时,只需计算其哈希值,即可快速定位到相应的存储位置。

2. 冲突解决

    然而,哈希函数并不是完美的。有时,不同的元素可能会计算出相同的哈希值,从而导致哈希冲突。为了解决这个问题,集合(以及字典)采用了各种冲突解决策略,如链地址法、开放地址法等。这些策略能够有效地处理哈希冲突,保证集合的正常运行。

三、集合的使用场景与示例

    集合在实际编程中有着广泛的应用场景。下面,我们将通过一些示例来说明集合的用途。

1. 去除重复元素

    假设你有一个包含重复元素的列表,你可以使用集合来轻松地去除这些重复元素。例如,你可以使用Python的set()函数将列表转换为集合,从而去除重复元素。以下是一个简单的示例:

# 原始列表,包含重复元素  
original_list = [1, 2, 3, 2, 4, 5, 5, 6]  # 将列表转换为集合,去除重复元素  
unique_set = set(original_list)  # 将集合转换回列表(如果需要)  
unique_list = list(unique_set)  print(unique_list)  # 输出:[1, 2, 3, 4, 5, 6]

2. 交集、并集和差集运算

    集合还支持交集、并集和差集等运算。这些运算在处理多个集合之间的关系时非常有用。以下是一些示例:

# 定义两个集合  
set1 = {1, 2, 3, 4}  
set2 = {3, 4, 5, 6}  # 交集运算  
intersection = set1 & set2  
print(intersection)  # 输出:{3, 4}  # 并集运算  
union = set1 | set2  
print(union)  # 输出:{1, 2, 3, 4, 5, 6}  # 差集运算(set1中有但set2中没有的元素)  
difference = set1 - set2  
print(difference)  # 输出:{1, 2}

    通过这些示例,我们可以看到集合在编程中的强大功能和灵活性。无论是去除重复元素还是进行集合运算,集合都能为我们提供高效且简洁的解决方案。 

 非常感谢您花时间阅读我的博客,希望这些分享能为您带来启发和帮助。期待您的反馈与交流,让我们共同成长,再次感谢!

👇热门内容👇 

python使用案例与应用_安城安的博客-CSDN博客

软硬件教学_安城安的博客-CSDN博客

Orbslam3&Vinsfusion_安城安的博客-CSDN博客

网络安全_安城安的博客-CSDN博客

教程_安城安的博客-CSDN博客

python办公自动化_安城安的博客-CSDN博客

👇个人网站👇

安城安的云世界

 

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

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

相关文章

Mysql函数

字符串函数 concat(s1,s2…sn)把传入的参数连接成一个字符串 注意:任何字符串与NULL进行连接的结果都将是NULL insert(str,x,y,instr)函数:将字符串str从第x位置开始,y个字符长度的字串替换为instr lower…

从“反超”到“引领”,中国卫浴品牌凭何遥遥领先?

作者 | 曾响铃 文 | 响铃说 前不久,第28届中国国际厨房、卫浴设施展览会(以下简称“中国国际厨卫展”)在上海如期举行,就结果来说真的让人大开眼界。 冲水声比蚊子声更小的马桶、能化身无感交互平台的魔镜柜、可以语音交互的淋浴器,这些“…

类与对象(上)

目录 ​编辑 一、面向过程和面向对象初步认识 二、类的引入 三、类的定义 四、类的访问限定符及封装 4.1 访问限定符 【面试题】 4.2 封装 【面试题】 五、类的作用域 六、类的实例化 七、类对象模型 7.1 如何计算类对象的大小 7.2 类对象的存储方式猜测 7.3 结…

Yolov9调用COCOAPI生成APs,APm,APl

最近在做小目标检测的东西,因为后期毕业论文需要,所以开始使用Yolov9模型,运行val.py的时候不会自己产生小目标的AP指标,所以研究了一下,步骤非常简单: 第一步: 在数据集中生成json格式的Annota…

ROS参数服务器

一、介绍 参数服务器是用于存储和检索参数的分布式多机器人配置系统,它允许节点动态地获取参数值。 在ROS中,参数服务器是一种用于存储和检索参数的分布式多机器人配置系统。它允许节点动态地获取参数值,并提供了一种方便的方式来管理和共享配…

开源大模型与闭源大模型

概述 开源大模型和闭源大模型是两种常见的大模型类型,它们在以下方面存在差异: 开放性: 开源大模型:代码和模型结构是公开可用的,任何人都可以访问、修改和使用。闭源大模型:模型的代码和结构是私有的&…

Thymeleaf 搭建家居网首页

文章目录 1.引入Thymeleaf sunliving-commodity模块1.在resources目录下引入Thymeleaf 所需资源2.pom.xml引入Thymeleaf依赖3.application.yml 关闭缓存,使页面实时刷新4.在application-prod.yml开启缓存5.编写com/sun/sunliving/commodity/web/IndexController.jav…

文心智能体大赛:百度文心智能体平台初体验

写在前面 博文内容涉及:文心智能体大赛:文心智能体初体验理解不足小伙伴帮忙指正 😃,生活加油 我徒然忘记了热闹,却来不及悟透真正的清冷(《四喜忧国》) 前言 徒然忘记了热闹,却来不及悟透真正的清冷(《四喜忧国》),在…

LiveGBS流媒体平台GB/T28181用户手册-版本信息:查看机器码、切换查看流媒体服务

LiveGBS流媒体平台GB/T28181用户手册--版本信息:查看机器码、切换查看流媒体服务 1、版本信息1.1、查看机器码1.2、多个流媒体服务1.3、提交激活 2、搭建GB28181视频直播平台 1、版本信息 版本信息页面,可以查看到信令服务 流媒体服务相关信息,包含硬件…

从XPS迁移到IP Integrator

从XPS迁移到IP Integrator 概述 AMD Vivado™设计套件IP集成器可让您将包含AMD的设计缝合在一起 IP或您的自定义IP在相对较短的时间内,在GUI环境中工作。 就像在Xilinx Platform Studio中一样,您可以快速创建嵌入式处理器设计(使用&#xff0…

[C++]debug介绍+debug时如何查看指针指向内存处的值

一、简介 预备工具和知识:使用使用VSCode使用Debug。 本文简介:本文将简要介绍debug中Continue,Step Over,Step Into和Restart的功能。并介绍如何在debug时查看动态内存地址(指针)的值; 二、D…

基于信号分解方法的机械故障诊断方法存在的问题

一方面,由于结构共振、测试噪声的干扰,为了确保分解精度,需要给定准确的参数初值(例如,瞬时频率)。研究人员通常认为零部件特征频率与通过传动比和驱动转速计算的理论值基本吻合,并基于理论值设置参数初值。事实上&…

upload-labs 21关解析

目录 一、代码审计 二、实践 三、总结 一、代码审计 $is_upload false; $msg null; if(!empty($_FILES[upload_file])){//检查MIME$allow_type array(image/jpeg,image/png,image/gif);if(!in_array($_FILES[upload_file][type],$allow_type)){$msg "禁止上传该类型…

【Docker学习】深入研究命令docker exec

使用docker的过程中,我们会有多重情况需要访问容器。比如希望直接进入MySql容器执行命令,或是希望查看容器环境,进行某些操作或访问。这时就会用到这个命令:docker exec。 命令: docker container exec 描述&#x…

【网络技术】【Kali Linux】Wireshark嗅探(十五)SSDP(简单服务发现协议)报文捕获及分析

往期 Kali Linux 上的 Wireshark 嗅探实验见博客: 【网络技术】【Kali Linux】Wireshark嗅探(一)ping 和 ICMP 【网络技术】【Kali Linux】Wireshark嗅探(二)TCP 协议 【网络技术】【Kali Linux】Wireshark嗅探&…

什么是聚簇索引和非聚簇索引,如何理解回表、索引下推

聚簇索引(Clustered Index)和非聚簇索引(Non-clustered Index)是数据库中的两种索引类型,它们在组织和存储数据时有不同的方式。 聚簇索引 聚簇索引简单理解就是将数据与索引放在一起,找到索引即找到了数…

第十三节:带你梳理Vue2 : watch侦听器

官方解释:> 观察 Vue 实例变化的一个表达式或计算属性函数。回调函数得到的参数为新值和旧值。表达式只接受监督的键路径。对于更复杂的表达式&#xff0c;用一个函数取代<br/>## 1. 侦听器的基本使用侦听器可以监听data对象属性或者计算属性的变化watch是观察属性的…

反弹shell详细易懂讲解,看这一篇就够了

文章目录 反弹shell详细易懂讲解&#xff0c;看这一篇就够了一: 基础shell知识什么是shell&#xff0c;bash与shell的区别?通俗解释类型功能常见命令 二: 什么是反弹shell三: 反弹shell类型bash反弹shellNetcat 一句话反弹curl反弹shell正确姿势 wget方式反弹awk反弹 Shellsoc…

[6] CUDA之线程同步

CUDA之线程同步 共享内存&#xff1a;线程时间需要互相交换数据才能完成任务的情况并不少见&#xff0c;因此&#xff0c;必须存在某种能让线程彼此交流的机制当很多线程并行工作并且访问相同的数据或者存储器位置的时候&#xff0c;线程间必须正确的同步线程之间交换数据并不…

前端:音频可视化(H5+js版本)

一、效果展示 HTML5JS实现一个简单的音频可视化 二、代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><title>音频可视化</title><style></style></head><body><divs…