python学习笔记2.6-集合(set)

一般来说,python中常用的数据结构是:列表(list)、字典(Dict)、元组(tuple)。但是我们常常还会看到另外一种结构:集合(set)。 个人认为,字典(dict)就是一种特殊的集合(set),它特殊的地方是集合的元素之间有一对一的对应关系。 集合,在定义上来说就是无序不重复的元素集,set里面可以是多种数据类型(但不能是列表,集合,字典,可以是元组)。 需要注意的是集合是无序的,所以不能用下标来访问。

## 1. 集合的创建

m = [1,2,9,6,3,4,6,7,8,7,6,4]
a = set(m)
print(a)

打印结果:
{1, 2, 3, 4, 6, 7, 8, 9}

## 2 集合的操作(s 代表一个集合) - 2.1 s.add( x ) 将元素 x 添加到集合s中,若重复则不进行任何操作

m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.add(7)
print(s)
s.add(10)
print(s)

打印结果:
{1, 2, 3, 4, 6, 7, 8, 9}
{1, 2, 3, 4, 6, 7, 8, 9, 10}
  • 2.2 update( x ) 将集合 x 并入原集合s中,x 还可以是列表,元组,字典等,x 可以有多个,用逗号分开
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
x = {11,5,45}
s.update(x)
print(s)

打印结果:
{1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 45}
  • 2.3 s.discard( x )将 x 从集合s中移除,若x不存在,不会引发错误
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.discard(5)
s.discard(77)
print(s)

打印结果:
{1, 2, 3, 4, 6, 7, 8, 9}
  • 2.4 remove( x ) 将 x 从集合s中移除,若x不存在,会引发错误
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.remove(4)
print(s)
s.remove(5)
print(s)

打印结果:
{1, 2, 3, 6, 7, 8, 9}
Traceback (most recent call last):
  File "D:/home/temp/temp_set.py", line 5, in <module>
    s.remove(5)
KeyError: 5

可以看出discard和remove的区别。

  • 2.5 pop() 随机删除并返回集合s中某个值(此功能有点儿奇怪)
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.pop()
print(s)
s.pop()
print(s)
  • 2.6 其他基本操作:
    clear():清空  
    in操作
    union( x ) 返回s与集合x的交集,不改变原集合s,x 也可以是列表,元组,字典。
    intersection( x ) 返回s与集合x的并集,不改变s, x 也可以是列表,元组,字典。
    difference( x )返回在集合s中而不在集合 x 中的元素的集合,不改变集合s, x 也可以是列表,元组,字典。
    s.symmetric_difference( x ) 返回s和集合x的对称差集,即只在其中一个集合中出现的元素,不改变集合s, x 也可以是列表,元组,字典。
    s.issubset( x ) 判断 集合s 是否是 集合x 子集
    s.issuperset( x ) 判断 集合x 是否是集合s的子集

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java帮帮-微信公众号-技术文章全总结

【Java提高十七】Set接口集合详解

三、Set接口 Set是一种不包括重复元素的Collection。它维持它自己的内部排序,所以随机访问没有任何意义。与List一样,它同样运行nu...

3509
来自专栏cs

c++13.0 STL[stack,queue,set,dequeue]

set相关知识点: ---- set:集合,红黑树实现 特点: 1.0 内部的元素根据其值自动排序。 2.0 内部元素只能出现一次。 set数据结...

2156
来自专栏软件开发 -- 分享 互助 成长

C++ STL之vector容器的基本操作

注意事项: 特别注意任何时候同时使用两个迭代器产生的将会是一个前闭后开的区间(具体见插入和删除的例子) 特别注意begin()指向的是vec中的第0个元素,而e...

2247
来自专栏从流域到海域

Python set(集合) 这一定是最全的介绍集合的博文

Python的set是一个无序且无重复元素的集合,概念上相当于数学上的无序集,数据结构上相当于dict的键。 既然set是集合,则必然可以实现并、交、...

1905
来自专栏抠抠空间

字典 (dict) 的增删改查及其他方法

一、字典的简介     字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据。python对key进行哈希函数运算,根据计算的结果...

2537
来自专栏Android开发指南

2 :基本语法

34011
来自专栏Java后端技术

Java Collection、Map集合总结

      依赖hashCode()和equals()两个方法进行保证元素唯一性,开发中使用开发工具自动生成就好。

502
来自专栏小樱的经验随笔

Codeforces 591B Rebranding

B. Rebranding time limit per test:2 seconds memory limit per test:256 megabytes ...

3357
来自专栏王磊的博客

es6新特性分享

1、字符串查找 es5使用是indexOf() 返回字符第一次出现的位置int值 es6新增了3个方法:includes()/startsWith()/endW...

3399
来自专栏haifeiWu与他朋友们的专栏

聊聊HashSet源码

今天聊一下HashSet源码,HashSet内部基本使用HashMap来实现,本博客将通过一下几个方向讲解。

753

扫码关注云+社区