Python内置数据结构——集合set

集合

定义

  • set翻译为集合
  • collection翻译为集合类型,是一个较大的概念
  • set是一个可变的、无序的、不重复的元素组成的集合
  • set的元素要求必须可以hash,目前已学的不可hash的类型只有list、set
  • 元素不可以索引
  • set可以迭代

set的初始化

  • set_1 =set() #表示定义一个空集合set_1
  • set_1 =set(iterable) #讲一个可迭代对象的元组添加到set_1这个集合中

set的操作

- add(elem)
    增加一个元素到set中,如果元素存在则什么都不做
- update(*others)
    合并其他元素到set中,参数others必须是可迭代对象;属于就地修改
- remove(elem)
    从set中移除一个元素,元素若不存在,则报keyerror
- discard(elem)
    从set中移除一个元素,若不存在则什么都不做
- pop()
    移除并返回任意元素。若是空set则返回keyerror
- clear()
    移除所有元素,若set很大会引起GC(内存垃圾回收)
- 修改
    在set中,要么删除,要么添加,由于set是无序的,只有通过hash值来查找元素,修改就相当于先删除再添加
- 查询
    非线性结构,无法索引;除非知道某个值确切再set中,通过hash值来查看
- 遍历
    可以迭代所有元素,
- 成员运算符
    in和not in判断元素是否再set中,由于是通过hash值来查找的,所以效率为O(1)

set和线性结构

  • 线性结构的查询时间复杂度是O(n),随着数据规模增大而增大加耗时
  • set、dict(dictionary字典)等结构,内部使用hash值作为key,时间复杂度可以做到O(1),查询时间和数据规模无关
  • 可hash
    - 数值型int、float、complex
    - bool型True、False
    - 字符串string、bytes
    - 元组tuple
    - None
    以上都是不可变类型,成为可hash类型(hashable)
  • set的元素必须是可hash的

集合的概念

  • 基本概念
- 全集
    所有元素的集合。例如正整数集,所有正整数组成的集合
- 子集subset和超集superset
    集合A的所有元素都在集合B中,称A是B的子集,B是A的超集
- 真子集和真超集
    A是B的子集,且A的元素比B少,则称A是B的真子集,B是A的真超集
- 并集是多个集合合并的结果
- 交集是多个集合的公共部分
- 差集是集合中出去交集外的部分
  • 集合运算
1. 并集
将两个集合A和B的所有元素合并到一起,组成的集合叫A和B的并集
    - union(*others)    返回和多个集合合并后的新的集合,例:s1.union(s2[,s3])
    - '|'运算符重载 等同于union,例:s1|s2[|s3]
    - update(*others)   和多个集合合并,就地修改,例:s1.update(s2[,s3])
    - '|='  等同于update,例:s1|= s2 [| s3]

2. 交集
集合A和集合B中所有同时属于A和B的元素组成的集合叫A和b的交集
    - intersection(*others) 返回多个集合的交集
    - '&'   等同于intersection
    - intersection_update(*others)  获取多个集合的交集,就地修改
    - '&='  等同于intersection_update
    
3. 差集
集合A和B,所有属于A切不属于B的元素组成的的集合
    - difference(*othens)   返回多个集合的差集
    - '-'   等同于difference
    - difference_update(*others)返回多个集合的差集并就地修改
    - '-='  等同difference_update

4. 对称差集
集合A和B,有所欲不属于A和B的交集元素组成的集合称为对称差集
    - symmetric_difference(other)   返回另一个集合的差集
    - '^'   等同于symmetric_difference
    - symmetric_difference_update(other)    获取和另一个集合的差集并就地修改
    - '^='  等同于symmetric_difference_update

- issubnet(other)、<=
    判断当前集合是不是另一个集合的子集
- set1 < set2
    判断set1是不是set2的真子集
- issuperset(other)、>=
    判断当前集合是不是other的超集
- set1 > set2 
    判断set1是不是set2的正超集
- isdisjoint(other)
    当前集合和另一个集合没有交集返回True,有交集返回False

练习

  • 随机产生2组10个数字的列表,取值范围[10,20]
    1. 统计20个数字中有多少个不同的数字
    2. 2组中,不重复的数字有几个,是什么
    3. 两组中重复的数字有几个是什么
import random


fst_nums = []
sec_nums = []
for _ in range(10):
    fst_nums.append(random.randint(10,20))
    sec_nums.append(random.randint(10,20))
print(fst_nums,sec_nums)    #created random sequence
print()

fst_nums,sec_nums = set(fst_nums),set(sec_nums)

print(fst_nums|sec_nums)
print(fst_nums ^ sec_nums)
print(fst_nums & sec_nums)

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/87628

(0)
KX_ilKX_il
上一篇 2017-10-03
下一篇 2017-10-03

相关推荐

  • 文件操作

    文件操作 冯诺依曼体系架构 CPU由运算器和控制器组成 运算器,完成各种算数的运算,逻辑运算,数据传输等数据加工处理 控制器,控制程序的执行 存储器,用于记忆程序的数据,列如内存 输入设备,将数据或者程序输入到计算机中列如键盘 鼠标 输出设备,将数据或者程序的处理结果展示给用户,列如显示器,打印机等等   一般说的IO操作,指的是文件的IO,如果是指网络的I…

    Python笔记 2018-05-02
  • Linux介绍

    Linux介绍 Linux概述 Linux概述 Linux内核由芬兰人Linus Torvalds 1991年根据386架构开发。Linux是系统的内核并非系统,之后的RED HALT 、Centos等都是以Linux为内核的类UNIX操作系统。 1969年UNIX系统由THOMPSON和D.M.Riche在美国贝尔实验室开发 1990年芬兰人Linus T…

    Python笔记 2018-03-26
  • 正则表达式

    正则表达式 分类 BRE:基本正则表达式,grep,sed,vi等软件支持,vim有扩展 ERE:扩展正则表达式,egrep,grep -E ,sed  r等 PCRE:几乎所有的高级语言都是PCRE的方言或则变种, 基本语法 元字符metacharater .  匹配除换行符外任意一个字符 [abc]字符集合,只能表示一个字符的位置,匹配所包含的任意一个字…

    Python笔记 2018-05-07
  • mysql慢查询日志进行按库切割重写文件然后分析

    需求: 把每天的慢查询日志进行按库切割 对每个库的慢查询日志进行分析 思路: 工具/功能 一般统计信息 高级统计信息 脚本 优势 mysqldumpslow 支持 不支持 perl mysql官方自带 mysqlsla 支持 支持 perl 功能强大,数据报表齐全,定制化能力强. mysql-explain-slow-log 支持 不支持 perl 无 my…

    Linux干货 2015-04-03
  • Python 部分知识点总结(十)

    此篇博客只是记录第十二周未掌握或不熟悉的知识点,用来加深印象。

    Python笔记 2018-05-28
  • Python面向对象基础

    语言分类 面向机器 抽象成机器指令,让机器容易理解 代表:汇编语言 面向过程 按照步骤一步一步走,若出现情况A做相应的处理,若出现情况B做相应的处理 问题规模小,可以步骤化,按部就班处理 代表:C 面向对象OOP 计算机需要处理的问题的规模越来越大,需要多人、多部门协作 代表:C++、Java、Python 面向对象 一种认识世界、分析世界的方法论。将万事万…

    2018-05-06