10_set集合
一、集合类型
集合是一组无序排列的可哈希的值(可哈希的值->不可变),集合成员可以做字典中的键。但集合本身是不可哈希的。
集合是无序没有索引,也没有像字典的key,所以集合不能更改元素。只能增删查(print、for循环)
集合的作用:
- 去重复元素
- 关系测试:交集、并集、差集、反交集、超集
二、集合的操作
1.集合的创建
#set 的创建
set1 = set('abcde') #def __init__(self, seq=()): 接受一个可迭代对象
set2 = {1,2,7,3,8,4,5,6} #直接赋值
print(set1)
print(set2)
2.去重
#利用set去重
li = [2,4,1,3,4,5,6,7,3,3]
set1 = set(li)
li = list(set1) print(li)
3.集合的增
3.1添加一个元素方法
#添加一个元素使用set.add()
set1 = {1,2,7,3,8,4,5,6}
set1.add('a') #Add an element to a set.
print(set1) #{1, 2, 3, 4, 5, 6, 7, 8, 'a'}
3.2迭代添加元素.接受一个可迭代对象,字符串、元组、列表、字典
#迭代添加
s1 = '中国'
set1 = {1,2,7,3,8,4,5,6}
set1.update(s1) #接受一个可迭代对象。把每个元素拆开,添加到set中
print(set1)
4.集合的删
4.1删除一个元素从set中
#删除一个元素从set中
set1 = {1,2,7,3,8,4,5,6,'a'}
set1.remove('a') #Remove an element from a set
print(set1)
4.2随机删除元素
#随机删,并返回被删除元素
set1 = {1,2,7,3,8,4,5,6,'a'}
set2 = set1.pop() #Remove and return an arbitrary set element. print(set2)
print(set1)
5.集合的其他操作
#1.print打印
set1 = {1,2,7,3,8,4,5,6,'a'}
print(set1) #2.for循环
for i in set1:
print(i) #3.in not in
print('a' in set1) #4.len()获取长度
print('集合长度:%d'%(len(set1)))
三、关系测试
交集
交集使用 & 或 intersection()
set1 = {1,2,3,4,5,6,7}
set2 = {3,4,5,6,7,8,9}
set3 = set1 & set2
set3 = set1.intersection(set2)
print(set3) #{3, 4, 5, 6, 7}
并集
并集: | 或者 union
set1 = {1,2,3,4,5,6,7}
set2 = {3,4,5,6,7,8,9}
set3 = set1 | set2
set3 = set1.union(set2)
print(set3) #{1, 2, 3, 4, 5, 6, 7, 8, 9}
差集
差集:两者各自特有的部分。使用 - 或者 difference()
#差集 : 两者做差,求各自特有的部分;该集合中的元素,只属于某一个集合,不属于另外那个集合
set1 = {1,2,3,4,5,6,7}
set2 = {3,4,5,6,7,8,9} #两种方式 - 或者 difference
set3 = set1 - set2 #两者做差,求各自特有的部分
set4 = set2 - set1 #两者做差,求各自特有的部分
set3 = set1.difference(set2)
set4 = set2.difference(set1) print(set3)#{1, 2} #set1特有的部分
print(set4)#{8, 9} #set2 特有的部分
反交集
反交集:^ 或者 symmetric_difference();该集合元素只能属于set1或者set2,不能同时set1又属于set2两个集合。->抛去两个集合相交的部分,把两者剩余的组成一个新集合。
#反交集:抛去他俩相同的部分,再组成一个新集合
set1 = {1,2,3,4,5,6,7}
set2 = {3,4,5,6,7,8,9} set3 = set1 ^ set2
set3 = set1.symmetric_difference(set2) print(set3) #{1, 2, 8, 9} 1,2是set1特有,8,9是set2特有
子集与超集
#子集与超集 : 检测某个集合是否是其他集合的超集或子集
#成立条件:set2必须得包含set1,并且含有set1没有的元素。set1不含有set2中的元素
set1 = {1,2,3,4,5,6,7}
set2 = {3,4,5,6,7,8,9}
set3 = {4,3} print(set2.issuperset(set1)) #False >=
print(set1.issuperset(set2)) #False
print(set2.issuperset(set3)) #True
print(set3.issubset(set2)) #True <= set3是set2的子集
10_set集合的更多相关文章
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- .Net多线程编程—并发集合
并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- java基础_集合List与Set接口
List接口继承了Collection的方法 当然也有自己特有的方法向指定位置添加元素 add(索引,添加的元素); 移除指定索引的元素 remove(索引) 修改指定索引的元素 set ...
- Java基础Collection集合
1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:
- 轻量级“集合”迭代器-Generator
Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...
- Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合
今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...
- 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)
在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...
随机推荐
- webshell 生成工具 b374k
还在为不会写webshell而感到心累?还在为webshell有后而不敢用?? b374k,我们首先去github下载b374k https://github.com/b374k/b374k.git ...
- HDU 2296:Ring
Problem Description For the hope of a forever love, Steven is planning to send a ring to Jane with a ...
- COGS 68. [NOIP2005] 采药【01背包复习】
68. [NOIP2005] 采药 ★ 输入文件:medic.in 输出文件:medic.out 简单对比 时间限制:1 s 内存限制:128 MB [问题描述] 辰辰是个天资聪颖的孩 ...
- 如何在VS2017中使用快捷键格式化代码?
1.同时按住Ctrl键+A键,全选代码或要格式化的部分代码: 2.再按住Ctrl键,接着按一下K键,接着按一下F键.(注意:Ctrl键在按后面这2个键的时候一直是按着的,直到F键按完才松开).也就是俗 ...
- JAVA爬虫实践(实践三:爬虫框架webMagic和csdnBlog爬虫)
WebMagic WebMagic是一个简单灵活的Java爬虫框架.基于WebMagic,你可以快速开发出一个高效.易维护的爬虫. 采用HttpClient可以实现定向的爬虫,也可以自己编写算法逻辑来 ...
- Coins、Tokens、山寨币:区别在哪里
[译] Coins, Tokens & Altcoins: What's the Difference? coin:指"正宗的"数字货币,比如比特币 tokens:比如用 ...
- 再起航,我的学习笔记之JavaScript设计模式29(节流模式)
节流模式 概念介绍 节流模式(Throttler): 对重复的业务逻辑进行节流控制,执行最后一次操作并取消其他操作,以提高性能. 优化滚动事件 有的时候我们再为滚动条添加动画的时候,会发现滚动条不停的 ...
- HDU 2243 Knight Moves
题目: A friend of you is doing research on the Traveling Knight Problem (TKP) where you are to find th ...
- ItemCF_基于物品的协同过滤_MapReduceJava代码实现思路
ItemCF_基于物品的协同过滤 1. 概念 2. 原理 如何给用户推荐? 给用户推荐他没有买过的物品--103 3. java代码实现思路 数据集: 第一步:构建物品的同现矩阵 第 ...
- 我在vs文本编辑中常用的快捷键----常更新
1. Ctrl+向上键----文本向上滚动 Ctrl+向下键----文本向下滚动 Ctrl+Enter-----向下增加一行 Ctrl+Shift+Enter-------向上增加一行 2. 避 ...