700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 07 基本数据类型的知识点补充 set()集合 深浅拷贝 冒泡算法

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

时间:2024-01-03 14:22:22

相关推荐

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) # 列表保存要删除的keyfor 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 copylst1 = ["超人", "七龙珠", "葫芦娃", "山中小猎人", ["金城武", "王力宏", "渣渣辉"]]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 = 0while i< len(li)-1: #把最大值移动到右边if li[i] > li[i+1]: #比较li[i],li[i+1]=li[i+1],li[i]#交换i = i + 1print(li)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。