#集合的创建
# set = set(["barry",1,2])
# print(set)
# set1 = {1,2,3}
#集合的增
# set1 = {'alex','wusir','ritian','egon','barry'}
# set1.add("taibai")
#
# set1.update("taibai") #迭代追加
# print(set1)
# 删
# set1 = {'alex','wusir','ritian','egon','barry'}
# # set1.pop() #随机删
# # set1.remove("alex") #指定元素删
# # set1.clear() #清空集合
# del set1 #删除集合
# print(set1)
#交集
# set1 = {1,2,3,4,5}
# set2 = {4,5,6,7,8}
# print(set1 & set2) # {4, 5}
# print(set1.intersection(set2)) # {4, 5}
#并集
# set1 = {1,2,3,4,5}
# set2 = {4,5,6,7,8}
# print(set1 | set2) # {1, 2, 3, 4, 5, 6, 7}
# print(set2.union(set1)) # {1, 2, 3, 4, 5, 6, 7}
#差集
# set1 = {1,2,3,4,5}
# set2 = {4,5,6,7,8}
# print(set1 - set2) # {1, 2, 3}
# print(set1.difference(set2)) # {1, 2, 3}
#反差集
# set1 = {1,2,3,4,5}
# set2 = {4,5,6,7,8}
# print(set1 ^ set2) # {1, 2, 3, 6, 7, 8}
# print(set1.symmetric_difference(set2)) # {1, 2, 3, 6, 7, 8}
#子集 是判断返回True或者False
# ) # 这两个相同,都是说明set2是set1超集set1 = {1,2,3}
# # set2 = {1,2,3,4,5,6}
# # print(set1 < set2)
# # print(set1.issubset(set2)) # 这两个相同,都是说明set1是set2子集。
# # print(set2 > set1)
# # print(set2.issuperset(set1)
#集合属于可变的类型,集合里面的元素属于不可变类型
#frozenset 将集合冻结,使其成为不可变类型
# s = frozenset("barry")
# print(s,type(s))

集合set

  集合要求里面的元素必须是不可变的数据类型,即int,字符串,bool。但是集合本身属于可变的数据类型

  集合里面的元素是不重复的(所以具有天然去重的特点),集合是无序的

  主要作用是:

    1.去重  (面试题:将list去重)

        l1 = [1,1,2,1,3,4,5,6,4,2,"alex","alex"]

     做法: set1 = set(l1)

        l2 = list(set1)

        print(l2)    #结果为[1,2,3,4,5,6,"alex"]

    2.关系测试,

      交集  &  intersection

      并集   |   union

      反交集 ^  difference

      子集  <  issubset  判断,a,b为俩个集合,如果是True,则说明a 是b的子集

      超集  >  issuperset            如果是False,则说明a是b的超集

  增  add  update

  删  pop  remove  clear(清空)   del (删除集合)

将集合变成不可变的数据类型即  frozenset()  冻结

# s = frozenset("barry")
# print(s,type(s)) #frozenset({'y', 'b', 'a', 'r'}) <class 'frozenset'>

深浅copy

1赋值运算

  

l1 = [1,2,3]
l2 = l1
l1.append(666)
print(l1)
print(l2)
print(id(l1),id(l2))
#[1, 2, 3, 666]
[1, 2, 3, 666]

2494346240904
2494346240904

  对于赋值运算来说,l1与l2指向的是同一个内存地址,所以他们是完全一样的。  即l1 is l2   为True

2.浅copy

  对于浅copy来说,第一层创建的是新的内存地址,而从第二层开始,指向的都是同一个内存地址,所以,对于第二层以及更深的层数来说,保持一致性。

3.deepcopy    深拷贝

  对于深copy来说,两个是完全独立的,改变任意一个的任何元素(无论多少层),另一个绝对不改变。

  面试题(切片属于浅copy)

  

l1 = [1,2,3,[22,33]]
l2 = l1[:]
# l1.append(666)
l1[-1].append(666)
print(l1,l2) #[1, 2, 3, [22, 33, 666]] [1, 2, 3, [22, 33, 666]]

最新文章

  1. Linux基础介绍【第五篇】
  2. Sql Server FOR XML PATH
  3. sass跨文件重写变量
  4. HTML5优点
  5. Jquery 中的$(this) 和javascript中的this
  6. Web API 简单示例
  7. SQL—— 事务
  8. iBatis 和MyBatis区别
  9. 深入理解urllib、urllib2及requests
  10. Qt中QFtp获取带有中文的文件名称出现乱码的解决方法(执行操作前就转换编码)
  11. Entity Framework中对存储过程的返回值的处理
  12. python中defaultdict的用法
  13. 用PE安装操作系统时:无法创建新的系统分区 也无法定位现有系统分区 的解决办法
  14. win10 uwp 访问解决方案文件
  15. Java多线程异常处理
  16. centos 如何关闭防火墙?
  17. [Swift]LeetCode267.回文全排列 II $ Palindrome Permutation II
  18. js&#183;逻辑运算
  19. 【学习总结】GirlsInAI ML-diary day-4:变量/Variable
  20. 西安80投影坐标系转WGS84地理坐标系如何求七参数

热门文章

  1. MySQL之视图篇
  2. 数据分析之客户价值模型(RFM)技术总结
  3. Mybatis结果映射器resultMap的基本用法
  4. etcd受损节点重新加入集群
  5. 使用动态时间规整 (DTW) 解决时间序列相似性度量及河流上下游污染浓度相似性识别分析
  6. ios plist获取权限
  7. TCP三次握手原理
  8. 使用Hot Chocolate和.NET 6构建GraphQL应用(9) —— 实现Mutate更新数据
  9. node + express本地搭建服务器,开启一个新的项目
  10. HDFS成员的工作机制