07 基本数据类型的知识点补充 set()集合 深浅拷贝 冒泡算法

主要内容:

  1.str.jion()

s = "abc"
s1 = s.join("非常可乐") # 把字符串s插入到"非常可乐"中
print(s1)

 jion可以把列表变成字符串,相应的split可以把字符串变成列表

s = "_".join(["alex", "wuse", "taibai", "ritian"])  # join可以把列表变成字符串, 把字符串变成列表.split()
print(s)                                            ####结果是:alex_wusir_taibai_ritian_sylar

  2.列表在循环的时候不能删除,因为索引会跟着改变,

lst = ["我不是药神", "西游记", "西红柿首富", "天龙八部"]
# list在循环的时候不能删. 因为会改变索引,所以要建一个新的列表,循环新的列表,将原来列表中的元素删除.
del_lst = []
for el in lst:
    del_lst.append(el)  # 记录下来要删除的内容
for el in del_lst:  # 循环记录的内容
    lst.remove(el)  # 删除原来的内容
print(lst)

    练习题:删除以周开头的元素

li = ["周星驰","周杰伦","周树人","马化腾"]
li1=[]
for el in li:
    if el.startswith("周"):
        li1.append(el)
for s in li1:
    li.remove(s)
print(li)

  3.字典也不能直接删除,要把删除的内容放在列表中,循环列表,删原来字典中的数.

lst = []
for k, v in zhubo.items():
    if v < avg:
        lst.append(k)   # 列表保存要删除的key
for el in lst:  # 迭代的是列表
    zhubo.pop(el)   # 删的是字典
print(zhubo)

  4.fromkeys() 不会对原来的字典产生影响,产生新的字典:

dic={}
s=dic.fromkeys("王健林", "思聪" )       #返回给一个新的字典
print(dic)
print(s) 
{}                                                #dic
{'王': '思聪', '健': '思聪', '林': '思聪'}           #s

   因为dict是一个类,可以指向指向对象

a = dict.fromkeys(["jj", 'jay', 'taibai'], "sb")  # 静态方法
print(a) #结果是:{'jj': 'sb', 'jay': 'sb', 'taibei': 'sb'}

  5.set()集合: set中的元素是不重复的.无序的.⾥面的元素必须是可hash的(int, str, tuple,bool), 我们可以这样来记. set就是dict类型的数据但是不保存value, 只保存key. set也用{}表示.

  注意:set集合中的元素必须是可hash的, 但是set本⾝身是不可hash得. set是可变的.

s = {123, {1,2,3}}    # 不合法
print(s)

  利用集合的无序,不重复,可以删除集合中的重复的元素;

lst=["张强","沥青","王磊",'liqing',"张强"]
s=set(lst)
print(s)

  添加:

s = {"刘嘉玲","关之琳","王祖贤"}
s.add("朱茵")
print(s)
s.add("朱茵")                    #重复的内容不会添加进去
s = {"刘嘉玲","关之琳","王祖贤"}
s.update("马化腾")               #迭代添加     
print(s)                        #  {'腾', '王祖贤', '关之琳', '刘嘉玲', '马', '化'}

  删除:

s = {"刘嘉玲","关之琳","王祖贤"}
s.remove("刘嘉玲")
s.remove("朱茵")              #如果不存在会报错
s.pop()                        #随机拿出一个删除
print(s)

  修改:

#set()集合中的数据没有索引,没有办法定位一个元素,所以没有办法直接修改。
#可以采用先删除后添加的方式来完成修改操作。

        查询:set()是一个可以迭代对象,可以使用for循环

s = {"刘嘉玲","关之琳","王祖贤"}
for el in s:
    print(el)

  6.深浅拷贝

    1:直接复制:两个变量指向同一个对象.

lst1 = ["金毛狮王", "紫衫龙王", "白眉鹰王", "青衣服往"]
lst2 = lst1 # 列表, 进行赋值操作. 实际上是引用内存地址的赋值. 内存中此时只有一个列表. 两个变量指向一个列表
lst2.append("杨做事")  # 对期中的一个进行操作. 两个都跟着变
print(lst2)
print(lst1)

    2:浅拷贝:只拷贝第一层那内容.  copy()

浅拷贝 copy 创建新对象
lst1 = ["赵本山", "刘能", "赵四"]
# lst2 = lst1.copy()  # lst2 和lst1 不是一个对象了
lst2 = lst1[:]  # 切片会产生新的对象
lst1.append("谢大脚")
print(lst1, lst2)
# print(id(lst1), id(lst2))

    3:深度拷贝:对象中的所有内容都会被拷贝一份

lst1 = ["超人", "七龙珠", "葫芦娃", "山中小猎人", ["金城武", "王力宏", "渣渣辉"]]
lst2 = lst1.copy()  # 拷贝. 浅拷贝 拷贝第一层
lst1[4].append("大阳哥")
print(lst1, lst2)
# 深拷贝
import copy
lst1 = ["超人", "七龙珠", "葫芦娃", "山中小猎人", ["金城武", "王力宏", "渣渣辉"]]
lst2 = copy.deepcopy(lst1)  # 把lst1扔进去进行深度拷贝 , 包括内部的所有内容进行拷贝
lst1[4].append("大阳哥")
print(lst1, lst2)

  为什么要拷贝:因为拷贝比创建对象快的多.

  对列表进行从大到小进行排序

li=[12,34,2,34,6,5,7,90]
for a in range(len(li)):                             #记录内部循环的次数
    i = 0
    while i< len(li)-1:                               #把最大值移动到右边
        if li[i] > li[i+1]:                           #比较
            li[i],li[i+1]=li[i+1],li[i]               #交换
        i = i + 1
print(li)

  

 

 

 

posted @ 2018-07-10 17:18  ...绿茵  阅读(202)  评论(0编辑  收藏  举报
1