day 007 深浅拷贝
今日内容:
1.字符串操作补充:
join # 遍历列表
例:
lst = ['汪峰','吴君如','章子怡']
s = '*-/@'.join(lst)
prints(s)
结果为汪峰*-/@吴君如*-/@章子怡
即把列表中的每一项用' '里边的东西进行拼接 结果为 字符串
而lst.split()正好相反
2.删除
例:
lst = ['渣渣辉',''古天乐'','陈小春','石榴姐']
# ls.clear() 没问题
但是用
for el inlst : 内部有一个变量来记录当前被循环的位置,索引.
lst.remove(el) # 直接删除,删不干净.原因是每次删除都涉及到元素的移动,索引在变
总结:
1.循环迭代过程中不能删除
2.要想删除可以创建新列表,先把要删除的内容保留到新列表中.循环这个新列表,删 除老列表
3.字典在循环过程中可以修改,但不能新增和删除.
newlst = []
for el in lst :
newlst.append(el)
for el in newls:
lst.remove(el)
3.fromkeys
字典的fromkeys # fromkeys 是一个类方法,作用是创建新字典
原字典没有改变
dic.fromkeys(k,v)
把k迭代和value组成k:v字典,所有的key共享一个value
所有的key用的都是同一个列表,改变其中一个另一个也相应改变
4.set集合
不重复 无序 不可变 (可哈希)
lst(set(lst))可以用来去除列表中的重复出现的元素
字典里的key不会重复
空集合 s = set()
s = {1,2,3,4,5} # 不重复,必须是可哈希的
# set其实就是不存在value 的字典 只存在key
应用 :去重复
set 无索引 因为无顺序
set 的增删改查
1.增:
s.add('要添加的东西')
s.update()迭代更新
2.删:
item = s.pop()
s.remove('要删除的对象')指定删除某对象
3.改
先删除再添加 s.remove('要删除的对象')之后 s.add('要添加的对象')
4.查
- for el in s :
- print(el)
- 深浅拷贝
- 1.赋值 不会产生新对象 和拷贝没关系,多个变量共享同一个对象
- 2.浅拷贝 只会复制自身.会创建对象新的对象中里面的对象不会被拷贝
- 3.深拷贝 把内部所有内容都进行拷贝.会创建一个一模一样的完全新的对象.这个对象延伸出来的内容也会跟着复制一份
- 冒泡排序
作业
第一题
while 1:
a = input("请随机输入一个三位数").strip()
if len(a) == 3:
sum =
for el in a:
sum += int(el)**3 print (sum)
if int(a) == sum: print("%s是水仙花数"%(a))
break
else:
print("%s不是水仙花数" % (a))
break
else:
print ("输入不合法请重新输入")
continue
2
a = int(input("请输入一个数"))
b = int(input("请再输入一个数"))
print('交换前的数字为a = %s,b = %s'%(a,b))
c = a
a = b
b = c
print('交换后的数字为a = %s,b = %s'%(a,b))
3
a = ['3','2','100','8','6','66','5']
b = []
for i in range(len(a)-1):
if int(a[i]) > int(a[i+1]):
k = a[i]
a[i] = a[i+1]
a[i+1] = k
print(a)
a = ['3','2','100','8','6','5','5','66','5']
count = 0
while count < len(a)-1:
for i in range(len(a)-1):
if int(a[i]) > int(a[i+1]):
k = a[i]
a[i] = a[i+1]
a[i+1] = k
count += 1
print(a)
3 from random import randint
count = 1
s = set()
while count <= 7:
n = randint(0, 36)
s.add(n)
count += 1
print(s)
sal = int(input("请输入您的税前工资:").strip())
if sal <= 2000:
print("您不用交税")
elif sal > 2000 and sal <= 4000:
money = (sal - 2000)*0.97
print("您到手工资为%s元"%(money))
elif sal > 4000 and sal <= 6000:
money = (sal-4000)*0.95 + 2000*0.97+
print("税后收入为%s元"%(money))
elif sal > 6000 and sal <= 10000:
money = (sal-6000)*0.92 + 2000*0.95 + 2000*0.97
print("税后收入为%s元"%(money))
else:
money = (sal - 10000) * 0.8 + 4000 * 0.92 + 2000*0.95 + 2000*0.97
print("税后收入为%s元"%(money))
day 007 深浅拷贝的更多相关文章
- Python 从零学起(纯基础) 笔记 之 深浅拷贝
深浅拷贝 1. import copy#浅拷贝copy.copy()#深拷贝copy.deepcopy()#赋值 = 2. 对于数字和字符串而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个 ...
- python——赋值与深浅拷贝
初学编程的小伙伴都会对于深浅拷贝的用法有些疑问,今天我们就结合python变量存储的特性从内存的角度来谈一谈赋值和深浅拷贝~~~ 预备知识一——python的变量及其存储 在详细的了解python中赋 ...
- Python中的深浅拷贝
1.什么是深浅拷贝? python中一切皆对象,python中的数字.字符串.元组等,如果存放在了内存中,这部分内存里面的内容是不会改变的,但是也有情况,内存中存放了可变对象,比如说列表和字典,他们的 ...
- Python-Day3知识点——深浅拷贝、函数基本定义、内置函数
一.深浅拷贝 import copy #浅拷贝 n1={'k1':'wu','k2':123,'k3':['carl',852]} n2=n1 n3=copy.copy(n1) print(id(n1 ...
- python基础知识5——赋值与深浅拷贝——整数和字符串,列表元组字典
深浅copy 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. 1 import copy 2 # ######### 数字.字符串 #### ...
- python 学习笔记5(深浅拷贝与集合)
拷贝 我们已经详细了解了变量赋值的过程.对于复杂的数据结构来说,赋值就等于完全共享了资源,一个值的改变会完全被另一个值共享. 然而有的时候,我们偏偏需要将一份数据的原始内容保留一份,再去处理数据,这个 ...
- Python开发【第二章】:Python深浅拷贝剖析
Python深浅拷贝剖析 Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 ...
- python基础(三元运算+深浅拷贝+函数参数)
三元运算 三元运算,又称三目运算,主要作用是减少代码量,是对简单的条件语句的缩写. 书写格式: result = 值1 if 条件 else 值2 即如果条件成立,则将值1赋给result变量,如果不 ...
- @proprety数组字典字符串用copy和strong区别(深浅拷贝)
//// @proprety数组字典字符串用copy和strong区别(深浅拷贝).h// IOS笔记//// /* _proprety________copy_strong_________h ...
随机推荐
- solr-用mmseg4j配置同义词索引和检索(IKanlyzer需要修改源码适应solr接口才能使用同义词功能)
概念说明:同义词大体的意思是指,当用户输入一个词时,solr会把相关有相同意思的近义词的或同义词的term的语段内容从索引中取出,展示给用户,提高交互的友好性(当然这些同义词的定义是要在配置文件中事先 ...
- 204. Count Primes 统计<n的质数的个数
[抄题]: Count the number of prime numbers less than a non-negative number, n. [暴力解法]: 时间分析: 空间分析: [优化后 ...
- 算法Sedgewick第四版-第1章基础-2.1Elementary Sortss-001选择排序法(Selection sort)
一.介绍 1.算法的时间和空间间复杂度 2.特点 Running time is insensitive to input. The process of finding the smallest i ...
- 算法Sedgewick第四版-第1章基础-1.4 Analysis of Algorithms-003定理
1. 2. 3. 4. 5. 6.
- 85D Sum of Medians
传送门 题目 In one well-known algorithm of finding the k-th order statistics we should divide all element ...
- Luogu 3586 [POI2015]LOG
考虑离散化后开权值线段树. 设序列中不小于$s$的数有$cnt$个,小于$s$的数的和为$sum$. 那么操作Z能成功的充要条件是$sum \geq (c - cnt) * s$. 如果序列中不小于$ ...
- kafka的producer执行卡住的问题
使用windows开发producer然后向远程的kakfa集群发送数据,但是一直卡着, 在window的hosts文件添加kafka集群的主机名和ip的映射就好了 网上搜了下,大致是producer ...
- a标签空的情况下 IE6 IE7下点击无效
如果给空a标签定义了宽度和高度且使用了absolute,则在IE6和IE7中点击无效. 两种解决方法(主要是针对a标签不能设置背景情况): 1.给a标签添加样式:background: ...
- unity编辑器拓展
[ExecutelnEditMode] 在EditMode下也可以执行脚本,Unity默认情况下,脚本只有运行时被执行,加上此属性后,不运行程序也能执行.与PlayMode不同的是函数不会不停 ...
- html5 canvas绘制矩形和圆形
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...