列表编程复习题(2)
1、编写程序,生成包含1000个0~100的随机整数,并统计每个元素出现的次数。
import random
list_ = [random.randrange(0, 101) for i in range(1000)]
# 集合化:去重
list_gather = set(list_)
for i in list_gather:
if (i + 1) % 5 == 0: # 控制格式输出
print("{}出现了{}次".format(i, list_.count(i)))
else:
print("{}出现了{}次\t\t\t".format(i, list_.count(i)), end='')
2、编写程序,用户从键盘输入小于1000的整数,对其进行因式分解。例如,10=2x5。
num = eval(input("请输入一个整数(小于1000):"))
result = [str(num) + "="]
i = 1
while i <= num:
if num % i == 0: # num 能被 i 整除,所以 i 可以做因数
num /= i
if num == 1:
result.append(str(i))
break
result.append(str(i) + "x")
i = 2 # i 从2开始重新遍历
continue
i += 1
for i in result:
print(i, end='')
3、L=[1,2,3,1,2,3,2,4], 要求:排序从大到小;过滤相同的数,相同的个数越多,排在前曲;个数相同,元素从小到大排列。
L = [1, 2, 3, 1, 2, 3, 2, 4]
L_new = [] # 结果列表
L_count = [] # 统计列表
L.sort()
L_set = set(L) # 集合化:去重
# 统计L_set集合中元素在L中的数量,并放在列表L_count中
for i in L_set:
L_count.append(L.count(i))
L_count.sort()
while len(L_set) > 0: # 当L_set中元素都统计完时结束
# 提取出L_count中的最大值并移除
max_count = L_count.pop()
for count in L:
if count in L_set:
if L.count(count) == max_count:
L_new.append(count)
L_set.remove(count)
break
print(L_new)
4、去除列表中的重复元素,L=[‘b’, ‘c’, ‘d’, ‘c’, ‘b’, ‘a’, ‘a’]
# 法一:
L = ['b', 'c', 'd', 'c', 'b', 'a', 'a']
for i in L:
if L.count(i) == 1:
continue
L.remove(i)
print(L)
# 法二
L = ['b', 'c', 'd', 'c', 'b', 'a', 'a']
L = list(set(L))
print(L)
5、从键盘输入整数x,判断它是否集合a, b, c的元素,若是分别输出1,2,3,若都不是输出4.要求集合a从键盘输入。
a_num = eval(input("请输入a集合的元素个数:"))
a_set = set()
for i in range(a_num):
set_element = input("请输入a集合的第{}个元素:".format(i + 1))
a_set.add(set_element)
num = eval(input("请输入一个整数:"))
b_set = {'1', 1, '2', 2, '你好', 123, '456', 789}
c_set = {'小沐', 0, 5, 6, 'str'}
if num in a_set or num in b_set or num in c_set:
print("1, 2, 3")
else:
print("4")
6、现在 dict2 = {“K1”: “v11”, “a”: “b”},通过一行操作使 dict2 = {“k1”: “v1”, “k2”: “v2”, “k3”: “v3”, “a”: “b”}
dict2 = {'K1': 'v11', 'a': 'b'}
dict2.update({'K1': 'v1', 'K2': 'v2', 'K3': 'v3'})
print(dict2)