(小甲鱼python)集合笔记合集一 集合(上)总结 集合的简单用法 集合的各种方法合集:子、交、并、补、差、对称差集、超集

news2025/1/11 18:49:11

一、基础复习

集合与字典区别

集合中所有元素都是独一无二的,并且也是无序的。
集合具有唯一性、无序性、有限性

>>> type({})           #字典
<class 'dict'>
>>> type({"one"})     #集合
<class 'set'>
>>> type({"one":1})   #字典
<class 'dict'>

二、集合的简单用法

1.集合创建的三种方法

#第一种是花括号里面传入多个元素
>>> {"FishC","Python"}
{'Python', 'FishC'}

#第二种是集合推导式
>>> {s for s in "FishC"}    # 集合中元素是无序的
{'s', 'i', 'F', 'C', 'h'}

#第三种是 set()方法
#这里源码是set(iterable),所以传入的"FishC"会被看作是可迭代对象进行迭代,而不是单个字符串
>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}

2.集合是无序的,不能通过下标索引访问

>>> s=set("FishC")
>>> s[0]
Traceback (most recent call last):
  File "<pyshell#10>", line 1, in <module>
    s[0]
TypeError: 'set' object is not subscriptable

3.判断某一元素是否在集合中

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> 'C' in s
True
>>> 'c' in s   #字符不在集合中
False

4.访问集合元素
迭代方式访问

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> for each in s:
	print(each)

s
i
F
C
h

5.集合唯一性的几种用法
对列表重复元素进行去重,判断列表是否有重复元素

>>> set([1,1,2,3,5])     #对列表重复元素进行去重
{1, 2, 3, 5}
>>> 
>>> s=[1,1,2,3,5]    #判断列表是否有重复元素
>>> len(s)==len(set(s))
False

6.集合的浅拷贝

>>> s=[1,1,2,3,5]
>>> t=s.copy()
>>> t
[1, 1, 2, 3, 5]

三、 集合的各种方法合集:子、交、并、补、差、对称差集

1.集合的浅拷贝

>>> s=[1,1,2,3,5]
>>> t=s.copy()
>>> t
[1, 1, 2, 3, 5]

2.判断两个集合是否毫不相关
s.isdisjoint(other) 如果 s 集合中没有与 other 容器存在共同的元素,那么返回 True,否则返回 False

>>> s=set("FishC")
>>> s
{'s', 'i', 'F', 'C', 'h'}
>>> s.isdisjoint(set("Python"))  #返回False说明它们相关,有公共的h
False
>>> s.isdisjoint(set("JAVA"))     #两集合无关
True
>>> 
>>> s.isdisjoint("JAVA")     # 传入字符串,显然与集合无关
True
>>> s.isdisjoint("Python")   #传入字符串,显然与集合相关
False

3.子集
子集:对于两个集合 A、B,如果集合 A 中任意一个元素都是集合 B 中的元素,我们就说这两个集合有包含关系,称集合 A 为集合 B 的子集(Subset)

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> s.issubset("FishC.com.cn")
True
>>> s.issuperset("Fish")
True

使用运算符,符号两边都必须是集合类型的数据才行,否则会报错,错误用法:

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> s<="FishC"
Traceback (most recent call last):
  File "<pyshell#58>", line 1, in <module>
    s<="FishC"
TypeError: '<=' not supported between instances of 'set' and 'str'
>>> 

运算符方法检测: 真集使用小于号 <

>>> s <=set("FishC")    #真集
True
>>> s<set("Fish")  
False
>>> s<set("FishC")
False
>>> s<set("FishC.com.cn")    #真子集
True

4.并集
并集:对于两个集合 A、B,把他们所有的元素合并在一起组成的集合,叫做集合 A 与集合 B 的并集(Union)。

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> s.union({1,2,3})
{1, 2, 3, 'C', 's', 'h', 'i', 'F'}

>>> s.union({1,2,3},"python")
{'y', 1, 2, 3, 's', 'F', 'p', 'i', 't', 'n', 'C', 'o', 'h'}

运算符方法检测:并集使用管道符
这条竖线 | 称为管道符

>>> s | {1,2,3} | set("Python")
{'y', 1, 2, 3, 'P', 's', 'i', 'F', 't', 'n', 'C', 'o', 'h'}

5.交集

交集:对于两个集合 A、B,由所有属于集合 A 且属于集合 B 的元素所组成的集合,叫做集合 A 与集合 B 的交集(Intersection)。

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> s.intersection("Fish")
{'h', 'i', 'F', 's'}

>>> s.intersection("Php","Python")
{'h'}

运算符方法检测:交集使用&符号

>>> s & set("Php") & set("Python")
{'h'}

5.差集
差集:对于两个集合 A、B,由所有属于集合 A 且不属于集合 B 的元素所组成的集合,叫做集合 A 与集合 B 的差集(Difference)。

>>> set("FishC")
{'s', 'i', 'F', 'C', 'h'}
>>> s.difference("Fish")
{'C'}

>>> s.difference("Php","Python")
{'C', 's', 'i', 'F'}

运算符方法检测:差集使用减号 -

>>> s - set("Php") - set("Python")
{'i', 'C', 'F', 's'}

6.对称差集
s.symmetric_difference(other) 返回一个新集合,其内容是排除掉 s 集合和 other 容器中共有的元素后,剩余的所有元素。

>>> s.symmetric_difference("Python")
{'y', 'P', 's', 'i', 't', 'F', 'n', 'C', 'o'}

运算符方法检测:对称差集使用脱字符 ^

>>> s ^ set("Python")
{'y', 'P', 's', 'F', 'i', 't', 'n', 'C', 'o'}

7.超集
使用运算符判断集合大小

>>> s>set("FishC")    #真超集
False
>>> s>=set("FishC")  #超集
True

课后题:
1.如果存在多个列表,需要筛出这些列表中相同的元素,可以使用什么方法?
答:将它们转换为集合,然后进行交集运算,得出的结果便是它们之间共同拥有的元素。
解析:

>>> # 方法一
>>> l1 = [1, 2, 3, 4, 5]
>>> l2 = [1, 3, 5, 7, 9]
>>> l3 = [1, 1, 2, 3, 5]
>>> set(l1).intersection(l2, l3)
{1, 3, 5}
>>> # 方法二
>>> set(l1) & set(l2) & set(l3)
{1, 3, 5}

2.请问下面代码的执行结果是?

>>> s1 = set("fishc.com.cn")
>>> s2 = set("ilovefishc.com")
>>> s1 - s2

答:{‘n’}
解析:集合之间使用减号(-)运算符,执行的是差集运算(就是找出存在于该集合,但不存在于其它集合中的元素),也可以使用 s1.difference(s2) 得到等值的结果。
3.请问下面三个图形中,A 和 B 通过什么操作会变成 C?
A.在这里插入图片描述B.在这里插入图片描述C.在这里插入图片描述答:对称差集。
解析:相当于偶数次重叠的有,奇数次重叠的没有。

题目来自小甲鱼 集合(上)

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

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

相关文章

微服务保护 Sentinel 实战

目录Sentinel什么是雪崩问题&#xff1f;服务保护技术对比Sentinel介绍和安装初识Sentinel安装Sentinel微服务整合Sentinel流量控制簇点链路快速入门流控模式关联模式链路模式流控效果warm up排队等待热点参数限流全局参数限流热点参数限流案例隔离和降级FeignClient整合Sentin…

nVisual各项隐藏项配置说明

nVisual可以部署在不同的项目中&#xff0c;但是每个项目都有自己不同的使用场景&#xff0c;有的不需要报表功能&#xff0c;有的不需要监测功能&#xff0c;还有的不需要连接外网的功能等。针对这些不同的需求&#xff0c;有必要且有可使用的机制来满足这些场景。 nVisual使…

PageRank算法

什么是PageRank&#xff1f; PageRankPageRankPageRank算法由GoogleGoogleGoogle创始人LarryPageLarry\ PageLarry Page在斯坦福大学时提出&#xff0c;又称PRPRPR&#xff0c;佩奇排名。主要针对网页进行排名&#xff0c;计算网站的重要性优化搜索引擎的搜索结果。PRPRPR值表示…

Java大学生档案系统高校学生档案系统

简介 Java基于springboot开发的学生档案系统&#xff0c;包含了权限管理&#xff0c;学生档案&#xff0c;学生成绩录入&#xff0c;教师管理等。 演示视频 https://www.bilibili.com/video/BV1XV411b761/?share_sourcecopy_web&vd_sourceed0f04fbb713154db5cc611225d92…

SQL速算N日留存

之前才哥发布了《用SQL进行用户留存率计算》 链接&#xff1a;https://mp.weixin.qq.com/s/QJ8JUO00bVJe_K6sx_ttaw 简化数据后得到如下结构的数据&#xff1a; 由于用户和登录日期被设置为主键所以不需要再进行去重&#xff0c;下面看看如何快速求七日留存。 数据下载地址&…

数据中心基础设施管理(DCIM)工具

什么是DCIM DCIM (Data Center Infrastructure management) 数据中心基础设施管理 是将IT&#xff08;信息技术&#xff09;和设备管理结合起来对数据中心关键设备进行集中监控、容量规划等集中管理。通过软件、硬件和传感器等&#xff0c;DCIM提供一个独立的管理平台&#xf…

网购平台如何保障公平交易

抢购&#xff0c;是这三年来重复出现的关键词。 疫情初始&#xff0c;口罩、测温枪是抢购热点&#xff1b;随后&#xff0c;蔬菜从口罩接过“抢购”接力棒&#xff1b;不久后&#xff0c;退烧药、抗原、血氧仪、“特效药”先后成为抢购热点&#xff1b;甚至元旦假期间&#xf…

【微服务】服务拆分及远程调用

文章目录服务拆分服务拆分原则服务拆分示例导入Sql语句导入demo工程实现远程调用案例案例需求分析注册RestTemplate实现远程调用提供者与消费者服务拆分 服务拆分原则 我们拿到一个单体架构&#xff0c;一般按照功能模块进行拆分。 微服务拆分时的几个原则&#xff1a; 不同…

数据结构_红黑树(C语言)

数据结构总目录红黑树 介绍&#xff1a; 红黑树是一种特化的AVL树&#xff08;平衡二叉树&#xff09;&#xff0c;都是在进行插入和删除操作时通过特定操作保持二叉查找树的平衡&#xff0c;从而获得较高的查找性能。红黑树是一种平衡二叉查找树的变体&#xff0c;它的左右子树…

JavaScript---DOM---节点操作---12.3

为什么学节点操作&#xff1f; 获取元素通常使用两种方式&#xff1a; 1.利用DOM提供的方法获取元素 document.getElementByld()document.getElementsByTagName()document.querySelector等逻辑性不强&#xff0c;繁琐 2.利用节点层级关系获取元素&#xff08;操作更简单&…

标准模板库STL

一、概述 1.1 STL的概念和作用 STL的概念&#xff1a;全称为 Standard Template Library STL的作用&#xff1a; 首先STL并不是语言的一部分&#xff08;一开始并没有&#xff09;它就是一个工具库, 没有这个工具时程序员写程序都要自己做&#xff08;例如&#xff1a;数据结…

软件生命周期阶段有几个?常见软件生命周期模型有哪些?

软件生命周期阶段及常见的软件生命周期模型&#xff0c;软件生命周期是指一个计算机软件从功能确定、设计&#xff0c;到开发 成功投入使用&#xff0c;并在使用中不断地修改、增补和完善&#xff0c;直到停止该软件的使用的全过程。  生命周期从收到应用软件开始算起&#x…

springboot 多模块项目构建【创建√ + 启动√ 】

一、多模块项目构建 1. 先建立父级目录demo-parent 2. 把父级目录src删除&#xff0c;再建立子级模块 3. 建立子级模块model,dao,service,common.utils等相同步骤 4. 建立启动模块boot, 创建Spring Boot 启动类 package com.example;import org.springframework.boot.SpringAp…

http服务转https服务(Nginx 服务器 SSL 证书安装部署)

安装的服务一直使用的是http&#xff0c;结果有客户要求必需使用https,下面是整理的步骤1、证书下载&#xff1a;&#xff08;要用域名申请的账号登录&#xff09;域名所在服务商一般都可以下载免费证书&#xff0c;我们用的域名是腾讯云的&#xff0c;所以在腾讯云上申请了免费…

高通开发系列 - gpio模拟输出PWM或者CLK时钟

By: fulinux E-mail: fulinux@sina.com Blog: https://blog.csdn.net/fulinus 喜欢的盆友欢迎点赞和订阅! 你的喜欢就是我写作的动力! 目录 问题背景平台信息GPIO输出CLKdts添加节点修改内核gcc时钟配置驱动文件编译运行gpio模拟PWM输出CLKdts中的配置GPIO模拟PWM驱动文件编译…

MSF信息收集

Nmap扫描 db_nmap -sV 192.168.1.0/24Auxiliary 扫描模块 ● RHOSTS表示 192.168.1.20-192.168.1.30 、 192.168.1.0/24,192.168.11.0/24&#xff08;扫描两个网段&#xff09; file:/root/host.txt (将需要扫描的主机访问文本中)● search arp use auxiliary/scanner/d…

网站收录查询方法,网站收录减少的原因

网站收录就是与互联网用户共享网址&#xff0c;网站收录前提是网站首页提交给搜索引擎&#xff0c;蜘蛛才会光顾&#xff0c;每次抓取网页时都会向索引中添加并更新新的网站&#xff0c;站长只需提供顶层网页即可&#xff0c;不必提交各个单独的网页。抓取工具能够找到其他网页…

华为matebook X 笔记本没开什么程序,有时经常慢卡

环境&#xff1a; 华为matebook X CPU &#xff1a;英特尔4核8线程10代 i5 内存&#xff1a;海力士16G 固态硬盘500G 问题描述&#xff1a; 华为matebook X 没开什么程序&#xff0c;经常慢卡&#xff0c;平时就是打开钉钉&#xff0c;处理处理文档&#xff0c;之前优化过…

模板题---1.5(单调栈,单调队列,kmp,manachar)

这里写目录标题1.单调栈2.单调队列3.kmp算法4.manachar算法这里记录几个基本的数据结构算法1.单调栈 要点&#xff1a; 数据结构是栈栈要维护单调性 这就是单调栈的基本定义 举个例子: &#xff08;栈底&#xff09;1 3 5 7 &#xff08;栈顶&#xff09; <-------这就是…

行为型模式 - 备忘录模式Memento

学习而来&#xff0c;代码是自己敲的。也有些自己的理解在里边&#xff0c;有问题希望大家指出。 模式的定义与特点 在备忘录模式&#xff08;Memento Pattern&#xff09;下&#xff0c;为的是在不破坏封装性的前提下&#xff0c;捕获一个对象的内部状态&#xff0c;并在该对象…