集合set-深入学习

集合set,无序,是不允许重复内容的,也就是不允许重复元素,如果有重复,会自动忽略,可接收可迭代类型 (一般用于需要判断和处理交集时候用到)

集合与字典的区别是,集合没有键只有值,字典是有键的字典是一对键值对

所以创建空集合不能用{}大括号,用大括号创建空集合默认会变成字典,如果需要创建空集合用set()

创建集合

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建集合
4 a = set()
5 a = {11,22,33,44,55,55}
6 print(a)
7 #打印出 {33, 11, 44, 22, 55}

集合的类库功能

 add(self*args, **kwargs)

"添加元素"(要添加的元素)

clear(self*args, **kwargs)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建一个集合
4 se = {11,22,33,44}
5 #向集合里添加元素
6 se.add(55)
7 print(se)
8 #打印出 {33, 11, 44, 22, 55}

"清空元素"()

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建一个集合
4 se = {11,22,33,44}
5 #清空集合里的元素
6 se.clear()
7 print(se)
8 #打印出 空集合

difference(self*args, **kwargs)

"查找出一个集合里存在,另外一个集合不存在的元素"(格式:查找集合.difference(被判断的集合)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {11,22,33,44}
5 b = {11,55,88,44}
6 #查找出a集合里存在,b集合不存在的元素
7 c = a.difference(b)
8 print(c)
9 #打印出 {33, 22}

difference_update(self*args, **kwargs)

"从当前集合中删除和B中相同的元素"(b集合)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {11,22,33,44,999}
5 b = {11,55,88,44}
6 #从a集合中删除和b集合中相同的元素
7 a.difference_update(b)
8 print(a)
9 #打印出 {33, 22, 999}

 discard(self*args, **kwargs)

"移除指定元素,不存在不报错"(要移除的元素)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建一个集合
4 a = {11,22,33,44,999}
5 #移除指定元素,不存在不报错
6 a.discard(999)
7 print(a)
8 #打印出 {33, 11, 44, 22}

intersection(self*args, **kwargs)

"交集,查找出a集合和b集合都存在的元素"(b集合

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {66,22,33,44,99}
5 b = {44,55,66,77,33}
6 #交集,查找出a集合和b集合都存在的元素
7 c = a.intersection(b)
8 print(c)
9 #打印出 {33, 66, 44}

intersection_update(self*args, **kwargs)

"交集,查找出a集合和b集合都存在的元素,并重新更新到a集合"(b集合

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {66,22,33,44,99}
5 b = {44,55,66,77,33}
6 #交集,查找出a集合和b集合都存在的元素,并重新更新到a集合
7 a.intersection_update(b)
8 print(a)
9 #打印出 {33, 66, 44}

isdisjoint(self*args, **kwargs)

"检查a集合和b集合是否有都存在的元素"(b集合

返回布尔值:如果没有都存在的,返回True,否则返回False

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {66,22,33,44,99}
5 b = {44,55,66,77,33}
6 #检查a集合和b集合是否有都存在的元素,
7 c = a.isdisjoint(b)
8 print(c)
9 #打印出 False 说明有交集

 issubset(self*args, **kwargs)

"判断一个集合是否是另一个集合的子序列"(b集合)

是返回True   不是返回False

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 #创建二个集合
 4 a = {11,22,33,44}
 5 b = {11,22}
 6 #检查a集合是否是b集合的子序列,
 7 c1 = a.issubset(b)
 8 print(c1)
 9 #检查b集合是否是a集合的子序列
10 c2 = b.issubset(a)
11 print(c2)
12 #打印出
13 #False 检查a集合是否是b集合的子序列,说明a集合不是b集合的子序列
14 #True  检查b集合是否是a集合的子序列,说明b集合是a集合的子序列

issuperset(self*args, **kwargs)

"判断一个集合是否是另一个集合的父序列"(b集合)

是返回True   不是返回False

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 #创建二个集合
 4 a = {11,22,33,44}
 5 b = {11,22}
 6 #检查a集合是否是b集合的父序列,
 7 c1 = a.issuperset(b)
 8 print(c1)
 9 #检查b集合是否是a集合的父序列
10 c2 = b.issuperset(a)
11 print(c2)
12 #打印出
13 #True  检查a集合是否是b集合的父序列,说明a集合是b集合的父序列
14 #False 检查b集合是否是a集合的父序列,说明b集合不是a集合的父序列

pop(self*args, **kwargs)

"移除元素"()

一般默认移除第一个元素,只是集合有一套自己的元素排序规则,

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 a = {44,55,66,77,88}
 4 #打印出集合,可以看到集合里的元素排序情况
 5 print(a)
 6 #移除集合里的元素,默认移除元素里的第一个排序元素
 7 b = a.pop()
 8 #打印出被移除的元素
 9 print(b)
10 #打印出a集合被移除后剩下的所有元素
11 print(a)
12 #最后打印出
13 #{88, 66, 44, 77, 55}
14 #88
15 #{66, 44, 77, 55}

remove(self*args, **kwargs)

"移除指定元素,不存在保错"(要移除的元素)

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3 a = {44,55,66,77,88}
 4 #打印出a集合
 5 print(a)
 6 #移除a集合里指定的元素
 7 a.remove(44)
 8 #打印a集合移除指定元素后,剩下的所有元素
 9 print(a)
10 #最后输出
11 #{88, 66, 44, 77, 55}
12 #{88, 66, 77, 55}
复制代码

 symmetric_difference(self*args, **kwargs)

"对称差集,就是将两个集合里没有交集的元素重新组合成一个新的集合"(b集合)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #对称差集,就是将两个集合里没有交集的元素重新组合成一个新的集合
6 c =  a.symmetric_difference(b)
7 print(c)
8 #输出
9 #{33, 66, 11, 77, 22, 88}

symmetric_difference_update(self*args, **kwargs)

"对称差集,并更新到a中,就是将两个集合里没有交集的元素重新组合更新给a集合"(b集合)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #对称差集,并更新到a中,就是将两个集合里没有交集的元素重新组合更新给a集合
6 a.symmetric_difference_update(b)
7 print(a)
8 #输出
9 #{33, 66, 11, 77, 22, 88}
复制代码

union(self*args, **kwargs)

"并集,将两个集合合并成一个新的集合,元素有重复的会自动忽略"(b集合)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #并集,将两个集合合并成一个新的集合,元素有重复的会自动忽略只保留一次
6 c = a.union(b)
7 print(c)
8 #输出
9 #{33, 66, 11, 44, 77, 22, 55, 88}

update(self*args, **kwargs)

"更新,将b集合更新到a集合,相当于合并"(b集合)

1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #更新,将b集合更新到a集合,相当于合并
6 a.update(b)
7 print(a)
8 #输出
9 #{33, 66, 11, 44, 77, 22, 55, 88}

时间: 2024-10-12 19:02:58

集合set-深入学习的相关文章

【DAY12】第十二天集合&泛型&IO学习笔记

hash:散列 ------------------ Hashset集合内部是通过HashMap进行实现的.使用的是HashMap中key部分. 对象在添加进集合中时,首选会对hashcode进行处理(hashcode右移16位和 自身做异或运算)得到一个经过处理的hash值,然后该值和集合的容量进行 &运算,得到介于0和集合容量值之间一个数字.该数字表示着数组的下标. 也就是该元素应该存放在哪个元素中. Map与Collection -------------- Map与Collection在

java 集合基础1 学习笔记

集合特点: 1.用于存储对象的容器. 2.集合的长度是可变的. 3.集合中不可以存储基本数据类型值. Collection接口常见方法: 1.添加 boolean add(obj); boolean addAll(Collection coll); 2.删除 boolean remove(obj); boolean removeAll(Collection coll); void clear();//清空集合 3.判断 boolean contains(obj); boolean contain

恶补java(十)---泛型与集合的再学习

其余的就不多说了,一切都在代码中 package com.gc.generic; /** * JDK5 之前集合对象使用问题: * 1.向集合添加任何类型对象 * 2.从集合取出对象时,数据类型丢失,使用与类型相关方法,强制类型转换 * 存在安全隐患 * * ***************************** * * JDK5中的泛型:允许程序员使用泛型技术限制集合的处理类型 * List<String> list=new ArrayList<String>(); * 从而

Java集合源码学习笔记(二)ArrayList分析

Java集合源码学习笔记(二)ArrayList分析 >>关于ArrayList ArrayList直接继承AbstractList,实现了List. RandomAccess.Cloneable.Serializable接口,为什么叫"ArrayList",因为ArrayList内部是用一个数组存储元素值,相当于一个可变大小的数组,也就是动态数组. (1)继承和实现继承了AbstractList,实现了List:ArrayList是一个数组队列,提供了相关的添加.删除.修

Java集合源码学习笔记(三)LinkedList分析

前面学习了ArrayList的源码,数组是顺序存储结构,存储区间是连续的,占用内存严重,故空间复杂的很大.但数组的二分查找时间复杂度小,为O(1),数组的特点是寻址容易,插入和删除困难.今天学习另外的一种常用数据结构LinkedList的实现,LinkedList使用链表作为存储结构,链表是线性存储结构,在内存上不是连续的一段空间,占用内存比较宽松,故空间复杂度很小,但时间复杂度很大,达O(N),链表的特点是寻址困难,插入和删除容易.所有的代码都基于JDK 1.6. >>关于LinkedLis

第七章 字典和集合[DDT书本学习 小甲鱼]【3】

4.copy() 复制字典a={1:"one",2:"two",3:"three"}b=a.copy()print(id(a))print(id(b))a[1]="four"print(a)print(b)-------------------24311023227282431102322800{1: 'four', 2: 'two', 3: 'three'}{1: 'one', 2: 'two', 3: 'three'}==

Java集合源码学习笔记(四)HashMap分析

ArrayList.LinkedList和HashMap的源码是一起看的,横向对比吧,感觉对这三种数据结构的理解加深了很多. >>数组.链表和哈希表结构 数据结构中有数组和链表来实现对数据的存储,这两者有不同的应用场景,数组的特点是:寻址容易,插入和删除困难:链表的特点是:寻址困难,插入和删除容易:哈希表的实现结合了这两点,哈希表的实现方式有多种,在HashMap中使用的是链地址法,也就是拉链法.看下面这张流传很广的图, 拉链法实际上是一种链表数组的结构,由数组加链表组成,在这个长度为16的数

Java集合框架的学习

本节内容总结来自传智播客毕向东老师的公开课,感谢毕向东老师 !如有错误之处,欢迎大家指教 ! Collection集合常用方法: 增加.删除.大小.包含(,包含所有).为空.清空.迭代.并交差: boolean add(E o);  boolean remove(Object o);  int size();  boolean contains(Object o);  boolean isEmpty();  void clear();  Iterator<E> iterator(); bool

关于guava 集合的一些学习笔记

public class SetGuava { public static void main(String[] args) { /** * Guava API 提供了有用的新的集合类型, 协同已经存在的java集合工作的很好. 分别是 Multimap, Multiset, * Table, BiMap, ClassToInstanceMap// */// System.out.println("Multimap:一种key可以重复的map,子类有ListMultimap和SetMultima