Python刷题系列(5)_set集合(下)

简介: set 是一个不允许内容重复的组合,而且set里的内容位置是无序的,所以不能用索引列出。可进行关系测试,删除重复数据,还可以计算交集、差集、并集等。

9、检查一个集合是否是另一个集合的子集


3580eed03aea4d56804f4d1cfed0a941.png

【1】使用<=

【2】使用issubset

setx = set(["apple", "mango"])
sety = set(["mango", "orange"])
setz = set(["mango"])
print("If x is subset of y:")
print(setx <= sety)
print(setx.issubset(sety))
print("If y is subset of x:")
print(sety <= setx)
print(sety.issubset(setx))
print("\nIf y is subset of z:")
print(sety <= setz)
print(sety.issubset(setz))
print("If z is subset of y:")
print(setz <= sety)
print(setz.issubset(sety))
'''
If x is subset of y:
False
False
If y is subset of x:
False
False
If y is subset of z:
False
False
If z is subset of y:
True
True
'''


10、从给定的集合中删除所有元素


编写一个Python程序以从给定的集合中删除所有元素。

setc = {"Red", "Green", "Black", "White"}    
setc.clear()
print(setc)
# set()

d8bdd0ac040240468218ef7ae921f8dc.png



11、在一个集合中查找最大值和最小值


147394a389f54cadaaf4f8a3ae4b38d3.png

#Create a set
setn = {5, 10, 3, 15, 2, 20}
print("Original set elements:")
print(setn)
print(type(setn))
print("\nMaximum value of the said set:")
print(max(setn))
print("\nMinimum value of the said set:")
print(min(setn))
'''
Original set elements:
{2, 3, 20, 5, 10, 15}
<class 'set'>
Maximum value of the said set:
20
Minimum value of the said set:
2
'''


12、查找集合的长度


编写一个 Python 程序来查找集合的长度。

#Create a set
setn = {5, 10, 3, 15, 2, 20}
print("Original set elements:")
print(setn)
print(type(setn))
print("Length of the said set:")
print(len(setn))
setn = {5, 5, 5, 5, 5, 5}
print("\nOriginal set elements:")
print(setn)
print(type(setn))
print("Length of the said set:")
print(len(setn))
'''
Original set elements:
{2, 3, 20, 5, 10, 15}
<class 'set'>
Length of the said set:
6
Original set elements:
{5}
<class 'set'>
Length of the said set:
1
'''

7b27036b9e53403a931b598a8477bcff.png



13、检查给定值是否存在于集合中


使用innot in

nums = {1, 3, 5, 7, 9, 11}
print("Test if 7 exists in nums:")
print(7 in nums)
print("Test if 6 is not in nums")
print(6 not in nums)
'''
Test if 7 exists in nums:
True
Test if 6 is not in nums
True
'''


14、检查两个给定的集合是否没有共同的元素


【1】isdisjoint

isdisjoint的功能

判断两个集合是否包含相同的元素,如果没有返回True,否则返回False


isdisjoint的用法

【1】语法:a_set.isdisjoint(b_set)

【2】参数:b_set:与当前集合用来判断的集合

【3】返回值:返回一个布尔值True或False

x = {1,2,3,4}
y = {4,5,6,7}
z = {8}
print("\nConfirm two given sets have no element(s) in common:")
print("\nCompare x and y:")
print(x.isdisjoint(y))
print("\nCompare x and z:")
print(z.isdisjoint(x))
print("\nCompare y and z:")
print(y.isdisjoint(z))
'''
Confirm two given sets have no element(s) in common:
Compare x and y:
False
Compare x and z:
True
Compare y and z:
True
'''



15、从第一组中删除第二组的交集


【2】difference_update


difference_update() 方法用于移除两个集合中都存在的元素。


difference_update() 方法与 difference() 方法的区别在于 difference() 方法返回一个移除相同元素的新集合,而 difference_update() 方法是直接在原来的集合中移除元素,没有返回值。


difference()移除元素后,需要一个新的“容器”去“承载”返回值。而difference_update() 是对集合的直接修改。


sn1 = {1,2,3,4,5}
sn2 = {4,5,6,7,8}
print("\nsn1中移除相同的元素,sn2不变")
sn1.difference_update(sn2)
print("sn1: ",sn1)
print("sn2: ",sn2)
'''
sn1中移除相同的元素,sn2不变
sn1:  {1, 2, 3}
sn2:  {4, 5, 6, 7, 8}
'''


相关文章
|
2月前
|
安全 网络安全 文件存储
思科设备巡检命令Python脚本大集合
【10月更文挑战第18天】
100 1
思科设备巡检命令Python脚本大集合
|
2月前
|
存储 NoSQL 关系型数据库
Redis 集合(Set)
10月更文挑战第17天
47 5
|
2月前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
53 6
|
2月前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
38 2
|
2月前
|
存储 算法 Java
Java Set因其“无重复”特性在集合框架中独树一帜
【10月更文挑战第14天】Java Set因其“无重复”特性在集合框架中独树一帜。本文深入解析Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定的数据结构(哈希表、红黑树)确保元素唯一性,并提供最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的`hashCode()`与`equals()`方法。
38 3
|
1月前
set集合
HashSet(无序,唯一): 基于 HashMap 实现的,底层采用 HashMap 来保存元素。 LinkedHashSet: LinkedHashSet 是 HashSet 的子类,并且其内部是通过 LinkedHashMap 来实现的。 TreeSet(有序,唯一): 红黑树(自平衡的排序二叉树)。
|
1月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
1月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
1月前
|
Java 开发者
|
2月前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
【10月更文挑战第16天】Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。通过 hashCode() 和 equals() 方法实现唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 添加和遍历元素,体现了 Set 的高效性和简洁性。
47 4