列表元组字典练习学习笔记4

练习题1:
"abcdefgh"里面挑出3个字母进行组合,一共有多少种组合,要求三个字母中不能有任何重复的字母,三个字母的同时出现次数,在所有组合中只能出现一次,例如出现了abc了,就不能出现cab和bca等。
提示:使用3个for遍历所有字母的组合,再增加条件判断把非法的给过滤除去。

result = []
for i in "abcdefgh":
    for j in "abcdefgh":
        for m in "abcdefgh":
            s = i+j+m
            if s.count(i) > 1 or s.count(j) > 1 or s.count(m) > 1:
                continue
            if sorted(list(s)) not in list(map(lambda x:sorted(list(x)),result)):
                result.append(s)

print(len(result))

在这里插入图片描述
练习题2:
复制一个列表,不能使用切片和复制的函数进行赋值,尽可能使用少的内置函数。

a = [1,2,3,4,5]
arr_length = 0
for i in a:
    arr_length+=1

def iter_arr(n):
    arr = []
    i = 0
    while i <=n-1:
        arr+=[i]
        i+=1
    return arr

result = [""]*arr_length
for i in range(arr_length):
    result[i] = a[i]

print(result)

在这里插入图片描述

深浅拷贝

Python中的对象之间赋值时是按引用传递的,如果
需要拷贝对象,需要使用标准库中的copy模块。

  1. copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象
    的内部的子对象。
  2. copy.deepcopy 深拷贝 拷贝对象及其子对象
import copy
a = [1, 2, 3, 4, 5, ['a', 'b']] # 原始对象
b = a # 赋值,传对象的引用
c = copy.copy(a) # 对象拷贝,浅拷贝
d = copy.deepcopy(a) # 对象拷贝,深拷贝
a.append(6) # 修改对象a
a[5].append('c') # 修改对象a中的['a', 'b']数组对象

print ('a = ', a)
print ('b = ', b)
print ('c = ', c)
print ('d = ', d)

在这里插入图片描述
小练习:
d={-1:100,-2:200,0:300,-3:200}按照key的大小顺序升序进行输出,输出key=value
-3=200,-2=200,-1=100,0=300

d={-1:100,-2:200,0:300,-3:200}
for key in sorted(d.keys()):
    print("%s = %s ," %(key,d[key]),end=" ")

在这里插入图片描述
练习2:
一个字符串排序,排序规则:小写<大小<奇数<偶数
原理:先比较元组的第一个值,FALSE<TRUE,如果相等比较元组的下一个值,以此类推。
先看一下Boolean value的排序:
print(sorted([True,False]))===>结果[False,True]
Boolean的排序会将False排在前,True排在后
s="9a13C85c7B24A6b"正确的顺序应该为:abcABC135792468

s="9a13C85c7B24A6b"
s="".join(sorted(list(s)))
lis = sorted(s,key=lambda x:(x.isdigit(),x.isdigit() and int(x)%2==0,x.isalpha() and x.isupper(),x.isalpha() and x.islower()))
print("".join(lis))

在这里插入图片描述
小写<大写<奇数<偶数
偶数(True,True,False,False)
奇数(True,False,False,False)
大写(False,False,True,False)
小写(False,False,False,True)

小练习:
生成一个字典,key是26个小写字母a-z,value是他的ascii码

d = {}
for i in range(97,123):
    d[chr(i)] = i

print(d)

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值