python 深浅拷贝 for循环删除

本文深入探讨了Python的基础数据类型,包括字符串操作、列表的深浅拷贝概念,以及字典的高级用法。同时,文章通过具体实例讲解了如何判断水仙花数,实现数字列表排序,计算个人所得税和企业奖金提成,以及开发彩票抽奖系统。
摘要由CSDN通过智能技术生成

###########################总结###########################

1. 基础数据类型补充
大多数的基本数据类型的知识.已经学完了

a='aaaa'
lst=['linux','alex','xsb']
s='+'.join(lst)
print(s) ##linux+alex+xsb

 

"*".join("马虎疼") # 马*虎*疼 把传递进去的参数进行迭代. 获取到的每个元素和前面的*进行拼接. 得到的是字符串
split() 切割. 切割的结果是列表

 

浅拷贝

lst1 = ["胡辣汤", "灌汤包", "油泼面", "麻辣香锅", ["长白山", "白洋淀", "黄鹤楼"]]
lst2 = lst1.copy() # 浅拷贝. 只拷贝第一层内容

print(id(lst1))
print(id(lst2))

print(lst1)
print(lst2)

lst1[4].append("葫芦娃")
print(lst1)
print(lst2)

38167112
43692424
['胡辣汤', '灌汤包', '油泼面', '麻辣香锅', ['长白山', '白洋淀', '黄鹤楼']]
['胡辣汤', '灌汤包', '油泼面', '麻辣香锅', ['长白山', '白洋淀', '黄鹤楼']]
['胡辣汤', '灌汤包', '油泼面', '麻辣香锅', ['长白山', '白洋淀', '黄鹤楼', '葫芦娃']]
['胡辣汤', '灌汤包', '油泼面', '麻辣香锅', ['长白山', '白洋淀', '黄鹤楼', '葫芦娃']]

深拷贝

# 引入一个模块
import copy

lst1 = ["胡辣汤", "灌汤包", "油泼面", "麻辣香锅", ["长白山", "白洋淀", "黄鹤楼"]]
lst2 = copy.deepcopy(lst1) # 深拷贝: 对象内部的所有内容都要复制一份. 深度克隆(clone). 原型模式

print(id(lst1))
print(id(lst2))

print(lst1)
print(lst2)

lst1[4].append("葫芦娃")
print(lst1)
print(lst2)

 

# 为什么要有深浅拷贝?
# 提高创建对象的速度
# 计算机中最慢的. 就是创建对象. 需要分配内存.
# 最快的方式就是二进制流的形式进行复制. 速度最快.

 

列表和字典: 都不能在循环的时候直接删除
把要删除的内容记录在新列表中然后循环这个新列表. 删除列表(字典)

lst=['篮球','排球','羽毛球','呵呵']
new_lst =[]
for el in lst:
    if "" in el:
        new_lst.append(el)
print(new_lst)

#循环新列表里面的值,删除老列表
for el in new_lst:
    lst.remove(el)
print(lst)

fromkeys()
坑1: 返回新字典. 不会更改老字典

dic = {}
d=dic.fromkeys("风扇哥","很困")
print(dic)#是空的 返回新的字典 和原来的 没有关系
print(d)#{'风': '很困', '扇': '很困', '哥': '很困'}

坑2: 当value是可变的数据类型. 各个key共享同一个可变的数据类型. 其中一个被改变了. 其他都跟着变

d= dict.fromkeys("胡辣汤",[])
print(d)#{'胡': [], '辣': [], '汤': []}
d[''].append('河南特色')
print(d)#{'胡': ['河南特色'], '辣': ['河南特色'], '汤': ['河南特色']}

# 程序员找工作和菜市场大妈买白菜是一样的

###########################作业###########################

1.判断一个数是否是水仙花数, 水仙花数是一个三位数, 三位数的每一位的三次方的和还等于这个数.
那这个数就是一个水仙花数, 例如: 153 = 1**3 + 5**3 + 3**3
n = input("请输入一个三位数:")  # 156
s = int(n[0])**3 + int(n[1])**3 + int(n[2]) ** 3
if int(n) == s:
    print("是水仙花数")
else:
    print("不是")


content=input('请输入数据:')
sum=0
for i in content:
    sum=sum + int(i)**3 #153
if sum== int(content):
    print(f'{content}是水仙花数')
else:
    print(f'{content}不是水仙花数')
2.给出一个纯数字列表. 请对列表进行排序(升级题).
思路:
1.完成a和b的数据交换. 例如, a = 10, b = 24 交换之后, a = 24, b = 10
2.循环列表. 判断a[i]和a[i+1]之间的大小关系, 如果a[i]比a[i+1]大. 则进行互换. 循环结束的时候.
当前列表中最大的数据就会被移动到最右端.
3.想一想, 如果再次执行一次上面的操作. 最终第二大的数据就移动到了右端. 以此类推.
如果反复的进行执行相应的操作. 那这个列表就变成了一个有序列表.

暂时空着
3.税务部门征收所得税. 规定如下: 
        1). 收入在2000以下的. 免征.
        2). 收入在2000-4000的, 超过2000部分要征收3%的税. 
        3). 收入在4000-6000的, 超过4000部分要征收5%的税.
        4). 收入在6000-10000的, 超过6000部分要征收8%的税.  
        4). 收入在10000以上的, 超过部分征收20%的税. 
    注, 如果一个人的收入是8000, 那么他要交2000到4000的税加上4000到6000的税加上6000到8000的税. 
        收入 = 8000-(4000-2000)*3%-(6000-4000)*4%-(8000-6000)*8%
让用户输入它的工资, 计算最终用户拿到手是多少钱.
salary = int(input("请输入你的工资:"))
if salary <= 2000:
print("你的税是0")
print("工资是%s" % salary)
elif salary <= 4000:
print("你的税是%s" % ((salary - 2000) * 0.03))
print("工资是%s" % (salary - ((salary - 2000) * 0.03)))
elif salary <= 6000:
print("你的税是%s" % ((2000*0.03) + (salary-4000)*0.05))
print("工资是%s" % (salary - ((2000*0.03) + (salary-4000)*0.05)))
elif salary <= 10000:
print("你的税是%s" % ((2000*0.03) + (2000*0.05) + (salary-6000)*0.08))
print("工资是%s" % (salary - ((2000*0.03) + (2000*0.05) + (salary-6000)*0.08)))
else: # 超过10000
print("你的税是%s" % ((2000 * 0.03) + (2000 * 0.05) + (4000 * 0.08) + (salary - 10000) * 0.2))
print("工资是%s" % (salary - ((2000 * 0.03) + (2000 * 0.05) + (4000 * 0.08) + (salary - 10000) * 0.2)))

企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%;
20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
i = float(input('请输入当月万利润'))
if i <= 10:
    bns = 10 * 0.1
elif 10 < i < 20:
    bns = 10 * 0.1 + (i - 10) * 0.075
elif 20 < i < 40:
    bns = 10 * 0.1 + 10 * 0.075 + (i - 20) * 0.05
elif 40 < i < 60:
    bns = 10 * 0.1 + 10 * 0.075 + 20 * 0.05 + (i - 40) * 0.03
elif 60 < i < 100:
    bns = 10 * 0.1 + 10 * 0.075 + 20 * 0.05 + 20 * 0.03 + (i - 60) * 0.015
elif i > 100:
    bns = 10 * 0.1 + 10 * 0.075 + 20 * 0.05 + 40 * 0.03 + 60 * 0.015+(i-100)*0.01
print(bns)
 
 

方法二

I = float(input("请输入当月利润,单位为万元:"))
bns = 0  #初始化奖金总数
cat = [100, 60, 40, 20, 10, 0]  #金额分6档
pct = [0.01, 0.015, 0.03, 0.05, 0.075, 0.1]  #每档的提成比例
for i in range(6):
    if I > cat[i]:
        I = I - cat[i]  #注意:刨掉档位金额后,应将值重新赋给I,每一档位分开计算
        bns = bns + I * pct[i]  #每一档位的奖金累计相加
print('当月应发放奖金总数为%s万元' % bns)

4.完成彩票36选7的功能. 从36个数中随机的产生7个数. 最终获取到7个不重复的数据作为最终的开奖结果.

随机数:
from random import randint
randint(0, 20) # 0 - 20 的随机数
from random import randint
s=set()
while len(s)<7:
    num=randint(1,36)
    s.add(num)
print(s)

# for : 确定循环范围. str, list, dic, tuple, set
# while: 不确定循环次数

转载于:https://www.cnblogs.com/zaizai1573/p/10066896.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值