练习题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模块。
- copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象
的内部的子对象。 - 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)