zoukankan      html  css  js  c++  java
  • 集合 copy


    #
    集合的创建 # 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]]
  • 相关阅读:
    转战博客园
    C++虐恋:MBCS安装失败导致的四天误工
    Servlet 3.0 新特性详解 (转载)
    数据库连接池proxool的两种使用方式
    java异常处理中的细节
    InvocationTargetException异常的深入研究-servlet的setAttribute与getAttribute
    如果我是一个全栈极客,那么,下一步该怎么走?
    C++基础与提高 001
    用户及文件权限管理
    命令行操作体验
  • 原文地址:https://www.cnblogs.com/yuncong/p/9454639.html
Copyright © 2011-2022 走看看