0. 集合的独白

  • 英文名: set
  • 我是数学中的一个基本概念,记得高中的“数学必修一”开篇讲的就是我;当然,高等数学开篇也是讲我。
  • 我可以没有元素,即“空集”
  • 我的元素排名不分先后,即“无序”
  • “弱水三千,只取一瓢饮”,即“不重复”

1. 集合的创建

  • 少废话,上例子
# 例1

s1_1 = set()
s1_2 = {1, 2, 3, 4, 5} print(s1_1)
print(type(s1_1))
print('-'*20) print(s1_2)
print(type(s1_2))
  • 运行结果

set()

<class 'set'>

--------------------

{1, 2, 3, 4, 5}

<class 'set'>


# 例2

s2 = {}

print(s2)
print(type(s2))
  • 运行结果

{}

<class 'dict'>

集合和“字典”都是用大括号括起来,并且空的大括号默认表示“字典”。

关于“字典”,就不挖坑了,讲完集合,之后就是“字典”。


2. 集合的特性

(1) 概述

  • 集合内数据“无序”,所以无法使用索引与分片
  • 集合内数据元素具有唯一性,所以可以用来排除重复数据
  • 集合内部只能放置可哈希数据,如 str、int、float、tuple、冰冻集合等
    • 关于“可哈希”与“不可哈希”,挖个坑,日后填平,编号 Py013-1
  • 序列运算、成员检测等

(2) 少废话,上例子

# 例3.1 序列不可相加

t3_1 = {1, 2, 3}
t3_2 = {4, 5, 6} print(t3_1) t3_1 = t3_1 + t3_2
print(t3_1)
  • 运行结果

{1, 2, 3}

TypeError……unsupported operand type(s) for +: 'set' and 'set'

集合不支持相加。


# 例3.2 序列可减

s3_3 = {1, 2, 3, 4, 5}
s3_4 = {4, 5}
s3_5 = {4, 5, 6, 7} s3_6 = s3_3 - s3_4
s3_7 = s3_3 - s3_5 print(s3_6)
print(s3_7)
  • 运行结果

{1, 2, 3}

{1, 2, 3}

集合间可使用“减法”,这种减法与概率统计中的减法很像。


# 例4 成员检测

s4 = {1, 2, 3, "I", "am", "YorkFish"}
print(s4) if "YorkFish" in s4:
print("Yes.") if "6" not in s4:
print("No.")
  • 运行结果

{'I', 1, 2, 3, 'am', 'YorkFish'}

Yes.

No.


3. 集合的遍历

  • 少废话,上例子
# 例5 for 循环

s5 = {1, 2, 3, "I", "am", "YorkFish"}

for i in s5:
print(i, end=' ') # end 是一个空格
  • 运行结果

I 1 2 3 am YorkFish


# 例6 集合内部嵌套了元组的遍历

s6 = {(1,2,3), ("I","am","YorkFish"), (4,5,6)}

for i in s6:
print(i)
print('-'*30) for k,m,n in s6:
print(k, "---", m, "---", n)
  • 运行结果

(4, 5, 6)

('I', 'am', 'YorkFish')

(1, 2, 3)

------------------------------

4 --- 5 --- 6

I --- am --- YorkFish

1 --- 2 --- 3


4. 集合内涵

  • 少废话,上例子
# 例7 普通的集合内涵

s7_1 = {6, 8, 34, 21, 56, 35, 6, 21, 9}
print(s7_1) s7_2 = {i for i in s7_1}
print(s7_2)
  • 运行结果

{34, 35, 6, 8, 9, 21, 56}

2229867508904

{34, 35, 6, 8, 9, 21, 56}

2229867508904

s7_1 与 s7_2 指向同一片地址,说明它们是同一个集合。


# 例8 带条件的集合内涵

s8_1 = {6, 8, 34, 21, 56, 35, 6, 21, 9}
s8_2 = {i for i in s8_1 if i % 2 == 0} # 取出 s8_1 的偶数 print(s8_1)
print(s8_2)
  • 运行结果

{34, 35, 6, 8, 9, 21, 56}

{8, 34, 56, 6}


# 例9 多循环的集合内涵

s9_1 = {1, 2, 3}
s9_2 = {"I", "am", "YorkFish"} s9_3 = {m*n for m in s9_1 for n in s9_2}
print(s9_3) s9_4 = {m*n for m in s9_1 for n in s9_2 if m == 2}
print(s9_4)
  • 运行结果

{'I', 'am', 'YorkFish', 'YorkFishYorkFishYorkFish', 'II', 'III', 'amam', 'YorkFishYorkFish', 'amamam'}

{'II', 'YorkFishYorkFish', 'amam'}


5. 集合的内置方法


6. 可供集合使用的一些方法/函数

(1) 又见测量君与最值双子

# 例10 len() max() min() 跟其他地方的用法基本一致

s10 = {6, 8, 34, 21, 56, 35, 6, 21, 9}

print(len(s10))
print( max(s10))
print(min(s10))
  • 运行结果

7

56

6

(2) “打不过就加入他们”

# 例11

list11_1 = [6, 8, 34, 21, 56, 35, 6, 21, 9]
s11_1 = set(list11_1)
print(s11_1) s11_2 = {6, 8, 34, 21, 56, 35, 6, 21, 9}
list11_2 = list(s11_2)
print(list11_2)
  • 运行结果

{34, 35, 6, 8, 9, 21, 56}

[34, 35, 6, 8, 9, 21, 56]

元组也是这样的。


(3) 冷酷的 frozenset

  • frozenset 即冰冻集合,是一种特殊的集合
  • frozenset 是不可以进行任何修改的集合
  • frozenset 有 8 个非魔法方法的方法
  • 简单举例
# 例12 创建

s12 = frozenset()

print(s12)
print(type(s12))
  • 运行结果

frozenset()

<class 'frozenset'>

[Python3] 013 集合:你不能两次进入同一个集合的更多相关文章

  1. Set集合对象比较两个元素的方法

    Set集合对象比较两个元素的方法并不是根据“equals()”方法的返回值来比较.而是用“hashCode()”方法来进行判断.只要两个元素的“hashCode()”方法的返回值相同,就认为两个元素相 ...

  2. python3 第十五章 - 数据类型之Sets(集合)

    python的官网里对集合的描述是: Python also includes a data type for sets. A set is an unordered collection with ...

  3. C# 实体/集合差异比较,比较两个实体或集合值是否一样,将实体2的值动态赋值给实体1(名称一样的属性进行赋值)

    /// <summary> /// 实体差异比较器 /// </summary> /// <param name="source">源版本实体& ...

  4. 从上面的集合框架图可以看到,Java 集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射

    从上面的集合框架图可以看到,Java 集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射.Collection 接口又有 3 ...

  5. Java 单个集合去重与两个集合去重

    一.单个集合去重 描述: 去掉一个集合里重复的元素:将list集合转成hashSet集合,hashSet有自动去重的功能,再利用去重后的hashSet集合初始化一个新的list集合,此时这个list就 ...

  6. java:在Conllection接口中实际上也规定了两个可以将集合变成对象数组的操作

    在Conllection接口中实际上也规定了两个可以将集合变成对象数组的操作 //在Conllection接口中实际上也规定了两个可以将集合变成对象数组的操作 List<String> a ...

  7. Collection两个常见的集合类型: ArrayList可重复集有序 ,HashSet不可重复集

    package seday11; import java.util.ArrayList; import java.util.Collection; import java.util.HashSet; ...

  8. POJ 1182食物链(分集合以及加权两种解法) 种类并查集的经典

    题目链接:http://icpc.njust.edu.cn/Problem/Pku/1182/ 题意:给出动物之间的关系,有几种询问方式,问是真话还是假话. 定义三种偏移关系: x->y 偏移量 ...

  9. Map集合迭代的两种方法

    import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; pub ...

随机推荐

  1. 北京师范大学第十五届ACM决赛-重现赛C Captcha Cracker (字符串模拟)

    链接:https://ac.nowcoder.com/acm/contest/3/C 来源:牛客网 Captcha Cracker 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26 ...

  2. UVa 10294(polya 翻转与旋转)

    Arif in Dhaka(First Love Part 2) Input: standard input Output: standard output Time Limit: 2 seconds ...

  3. 刷PTA这一周的感悟

    在慕课上报名了浙江大学的<数据结构>这门课,主讲人陈越老师,何钦铭老师,两位老师讲的很好,课后有配套的PTA可以用来做题,练习. 最近在PTA上刷题,发现自己代码实现能力是真的差劲,一开始 ...

  4. JVM GC Roots

    如何确定一个堆中的对象是否死去? 两个思路: 1.引用计数法 给每个对象添加一个引用,用来统计指向该对象的引用计数.有引用时就加1,引用失效时就减1.任何时候引用计数为0,该对象就死亡了.可以被当做垃 ...

  5. Python之常用模块一(主要RE和collections)

    一.认识模块  什么是模块:一个模块就是一个包含了python定义和声明的文件,文件名就是加上.py的后缀,但其实import加载的模块分为四个通用类别 : 1.使用python编写的代码(.py文件 ...

  6. NOIP2016 D1T1 玩具谜题

    洛谷P1563 看完了noip2017觉得noip2016是真的简单……2017第一题就卡住2016第一题10分钟AC 思路: m<=100000很明显暴力模拟就可以 唯一有一点点难度的地方就是 ...

  7. [原创]PHP代码修正之CodeSniffer

    目录 参考链接 介绍 安装 使用 命令行模式 PHPStorm 让编辑器使用PSR-2标准 集成phpcbf 参考链接 PHP开发规范之使用phpcbf脚本自动修正代码格式 在PhpStorm中使用P ...

  8. window7下docker toolbox 启用数据卷报错: Error response from daemon: invalid mode:

    场景:希望把d:\dockerShare文件夹作为数据卷 ,和docker中的centos镜像生成的容器关联. 原来的命令: docker run -d -it --name=edc-centos7 ...

  9. JS&ASPDotNet_大文件上传问题

    HTML部分 <%@PageLanguage="C#"AutoEventWireup="true"CodeBehind="index.aspx. ...

  10. makefile 打印

    $(warning ----------$(abc)) $(info -----------------$(abc))