零基础入门学习Python(27)--集合:在我的世界里,你就是唯一
知识点
集合:set
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
集合中的元素的三个特征:
1)确定性(元素必须可hash)
2)互异性(去重)
3)无序性(集合中的元素没有先后之分),如集合{3,4,5}和{3,5,4}算作同一个集合
【注意】:集合存在的意义就在于去重和关系运算。
创建集合
创建一个空集合需使用set() 工厂函数:
语法:
class set([iterable])
参数说明:
iterable -- 可迭代对象对象;
示例:
>>> set1 = set()
>>> type(set1)
<class 'set'>
>>> set2 = {11,22,33,12,11}
>>> type(set2)
<class 'set'>
>>> set2
{33, 11, 12, 22}
【注意】:注意在创建空集合的时候只能使用s=set(),因为s={}创建的是空字典
>>> a = set('boy') #set一个字符串
>>> a
{'b', 'y', 'o'}
>>> b = set(['y','b','o','o']) #set一个列表
>>> b
{'b', 'y', 'o'}
>>> f = set(('k1','k1','k2','k3',1,2)) #set一个元祖
>>> f
{1, 2, 'k2', 'k3', 'k1'}
>>> c = set({'k1':1,'k2':2,'k3':2}) #set一个字典
>>> c
{'k2', 'k1', 'k3'}
>>> type(c)
<class 'set'>
>>> d = {1,2,3,4}
>>> type(d)
<class 'set'>
>>> d
{1, 2, 3, 4}
>>> e = {(1,2,1,1)}
>>> e
{(1, 2, 1, 1)}
创建不可变集合
frozenset() 返回一个冻结的集合,冻结后集合不能再添加或删除任何元素。
语法:
class frozenset([iterable])
参数
iterable -- 可迭代的对象,比如列表、字典、元组等等。
示例:
>>>a = frozenset(range(10)) # 生成一个新的不可变集合
>>> a
frozenset([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
>>> b = frozenset('runoob')
>>> b
frozenset(['b', 'r', 'u', 'o', 'n']) # 创建不可变集合
>>> num3 = frozenset([1,2,3,4,5])
>>> num3
frozenset({1, 2, 3, 4, 5})
>>> num3.add(0)
Traceback (most recent call last):
File "<pyshell#42>", line 1, in <module>
num3.add(0)
AttributeError: 'frozenset' object has no attribute 'add'
集合的关系运算
in,not in:判断某元素是否在集合内
>>> a
{'b', 'y', 'o'}
>>> b in a
False
>>> 'b' in a
==,!=:判断两个集合是否相等
>>> a = {3,4,5}
>>> b = {4,3,5}
>>> a == b
True
集合的内建方法
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.issubset(t) | s <= t | 子集测试(允许不严格意义上的子集):s中所有的元素都是t的成员 |
| s < t | 子集测试(严格意义上):s中所有的元素都是t的成员 |
示例:
>>> s = {1,2,3,4}
>>> t = {1,2,3,4,5}
>>> s.issubset(t)
True
>>> s <= t
True
>>> s < t
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.issuperset(t) | s >= t | 超集测试(允许不严格意义上的超集):t中所有的元素都是s的成员 |
| s > t | 超集测试(严格意义上):t中所有的元素都是s的成员 |
示例:
>>> s = {1,2,3,4,5}
>>> t = {1,2,3}
>>> s.issuperset(t)
True
>>> s >= t
True
>>> s > t
True
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.union(t) | s | t | 合并操作:s “或” t 中的元素 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s.union(t)
{1, 2, 3, 4, 5}
>>> s|t
{1, 2, 3, 4, 5}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.intersection(t) | s & t | 交集操作:s “与” t 中的元素 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s & t
{2, 3, 4}
>>> s.intersection(t)
{2, 3, 4}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.difference(t) | s - t | 差分操作:在s中存在,在t中不存在的元素 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s - t
{1}
>>> s.difference(t)
{1}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.symmetric_difference(t) | s ^ t | 对称差分操作:s “或” t 中的元素,但不是s和t的共有元素 |
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s.symmetric_difference(t)
{1, 5}
>>> s ^ t
{1, 5}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| s.copy() | 返回s的浅拷贝 |
示例:
>>> a = {1,2,3}
>>> b = a.copy()
>>> b
{1, 2, 3}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.update(t) | s |= t | 将t中的元素添加到s中 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s |= t
>>> s
{1, 2, 3, 4, 5}
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s.update(t)
>>> s
{1, 2, 3, 4, 5}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.intersection_update(t) | s &= t | 交集修改操作:s中仅包括s和t中共有的成员 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s.intersection_update(t)
>>> s
{2, 3, 4}
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s &= t
>>> s
{2, 3, 4}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.difference_update(t) | s -= t | 差修改操作:s中包括仅属于s但不属于t的成员 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s -= t
>>> s
{1}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.symmetric_difference_update(t) | s ^= t | 对称差分修改操作:s中包括仅属于s或仅属于t的成员 |
示例:
>>> s = {1,2,3,4}
>>> t = {2,3,4,5}
>>> s ^= t
>>> s
{1, 5}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.add(obj) | 加操作:将obj元素添加到s中 |
示例:
>>> s = {1,2,3,4}
>>> s.add('fs')
>>> s
{1, 2, 3, 4, 'fs'}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.remove(obj) | 删除操作:将obj元素从s中删除,如果s中不存在obj,将引发异常 |
示例:
>>> s = {1, 2, 3, 4, 'fs'}
>>> s.remove('fs')
>>> s
{1, 2, 3, 4}
>>> s.remove('a')
Traceback (most recent call last):
File "<pyshell#182>", line 1, in <module>
s.remove('a')
KeyError: 'a'
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.discard(obj) | 丢弃操作:将obj元素从s中删除,如果s中不存在obj,也没事 |
示例:
>>> s = {1, 2, 3, 4, 'fs'}
>>> s.discard('fs')
>>> s
{1, 2, 3, 4}
>>> s.discard('a')
>>> s
{1, 2, 3, 4}
| 集合(s).方法名 | 等价符号 | 方法说明 |
|---|---|---|
| 以下方法不适用于不可变集合frozenset() | ||
| s.pop() | 弹出操作:移除并返回s中任意一个元素 | |
| s.clear() | 清除操作:请出s中所有的元素 |
>>> s = {1, 2, 3, 4}
>>> s.pop()
1
>>> s
{2, 3, 4}
>>> s.pop()
2
>>> s
{3, 4}
>>> s.clear()
>>> s
set()
课后习题
零基础入门学习Python(27)--集合:在我的世界里,你就是唯一的更多相关文章
- 【Python教程】《零基础入门学习Python》(小甲鱼)
[Python教程]<零基础入门学习Python>(小甲鱼) 讲解通俗易懂,诙谐. 哈哈哈. https://www.bilibili.com/video/av27789609
- 《零基础入门学习Python》【第一版】视频课后答案第001讲
测试题答案: 0. Python 是什么类型的语言? Python是脚本语言 脚本语言(Scripting language)是电脑编程语言,因此也能让开发者藉以编写出让电脑听命行事的程序.以简单的方 ...
- 零基础入门学习Python(1)--我和Python的第一次亲密接触
前言 最近在学习Python编程语言,于是乎就在网上找资源.其中小甲鱼<零基础入门学习Python>试听了几节课,感觉还挺不错,里面的视频都是免费下载,小甲鱼讲话也挺幽默风趣的,所以呢,就 ...
- 学习参考《零基础入门学习Python》电子书PDF+笔记+课后题及答案
国内编写的关于python入门的书,初学者可以看看. 参考: <零基础入门学习Python>电子书PDF+笔记+课后题及答案 Python3入门必备; 小甲鱼手把手教授Python; 包含 ...
- 学习《零基础入门学习Python》电子书PDF+笔记+课后题及答案
初学python入门建议学习<零基础入门学习Python>.适合新手入门,很简单很易懂.前一半将语法,后一半讲了实际的应用. Python3入门必备,小甲鱼手把手教授Python,包含电子 ...
- 零基础入门学习Python(36)--类和对象:给大家介绍对象
知识点 Python3 面向对象 Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的.本章节我们将详细介绍Python的面向对象编程. 如果你以前 ...
- 零基础入门学习Python(17)--函数:Python的乐高积木
前言 相信大家小时候都玩过神奇的乐高积木, 只要通过想象力和创造力我们可以拼凑很多神奇的东西,那么随着我们学习的深入,我们编写的Python代码也将日益增加,并且也越来越复杂, 所以呢,我们需要找寻一 ...
- 零基础入门学习Python(35)--图形用户界面入门:EasyGui
知识点 EasyGui学习文档[超详细中文版] 1. 建议不要在IDLE上运行EasyGui EasyGui是运行在TKinter上并拥有自身的事件循环,而IDLE也是Tkinter写的一个应用程序并 ...
- 零基础入门学习Python(13)--元组:戴上了枷锁的列表
前言 这节课我们讨论主题是元祖:我们有个小标题戴上了枷锁的列表 我们都知道早在300多年前,孟德斯鸠在变法的时候说过,一切拥有权力的人都容易被滥用权力,这是万古不变的一条经验.但是呢,凡是拥有大权利的 ...
随机推荐
- E201700525-hm
skeleton n. 骨骼; (建筑物等的) 骨架; 梗概; 骨瘦如柴的人(或动物);adj. 骨骼的; 骨瘦如柴的; 概略的; 基本的; cloud n. 云; 云状物; invoke ...
- HDU1254:推箱子(bfs+dfs)
传送门 题意 给出一副图 0.空地1.墙2.箱子3.目的地4.人所在的位置 问最少几步能将箱子推到目的地 分析 这道题难度略大(菜鸡),首先用vis[bx][by][mx][my]记录当箱子(bx,b ...
- 【插件开发】—— 12 GEF入门
介绍 前面也简单的介绍了一下插件开发的相关知识,下面主要就介绍一下GEF的相关使用.由于最近使用到编辑器这部分的操作,因此就跳过其他的内容,先介绍下GEF的相关知识. 前文回顾 1 插件学习篇 2 简 ...
- Ocelot(六)- 架构图
简介 Ocelot是一个用.NET Core实现并且开源的API网关,它功能强大,包括了:路由.请求聚合.服务发现.认证.鉴权.限流熔断.并内置了负载均衡器与Service Fabric.Butter ...
- Linux下UDP简介及程序设计
一.UDP简介 UDP(User Datagram Protocol),用户数据报协议,是OSI参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务.UDP提供了无连接通信,且不对传 ...
- 洛谷 P2617 Dynamic Rankings || ZOJ - 2112
写的让人看不懂,仅留作笔记 静态主席树,相当于前缀和套(可持久化方法构建的)值域线段树. 建树方法:记录前缀和的各位置的线段树的root.先建一个"第0棵线段树",是完整的(不需要 ...
- 暴力 BestCoder Round #46 1001 YJC tricks time
题目传送门 /* 暴力:模拟枚举每一个时间的度数 详细解释:http://blog.csdn.net/enjoying_science/article/details/46759085 期末考结束第一 ...
- Kuskal/Prim POJ 1789 Truck History
题目传送门 题意:给出n个长度为7的字符串,一个字符串到另一个的距离为不同的字符数,问所有连通的最小代价是多少 分析:Kuskal/Prim: 先用并查集做,简单好写,然而效率并不高,稠密图应该用Pr ...
- assets与res/raw资源目录的区别
1.简介 assets和res/raw工程目录下都可以放一些小于1M的文件(2.3版本以前要求,否则将不能读出数据.),这些文件将被原样打包到APK中应用使用. 2.不同 assets目录下的文件将原 ...
- 转】[MySQL优化]为MySQL数据文件ibdata1瘦身
原博文出自于: http://blog.fens.me/category/%E6%95%B0%E6%8D%AE%E5%BA%93/page/2/ 感谢! [MySQL优化]为MySQL数据文件ibda ...