1.生成50-300之间可重复的 10个数据 存放于列表中, 保证列表中元素的顺序,对列表进行排重,并对列表使用排序算法进行降序排序
例如:随机生成了[70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
--- 去重之后 [70, 88, 91, 107, 234, 177, 282, 197]
---- 降序排序 [282, 234, 197, 177, 107, 91, 88, 70]
import random
list1 = []
for x in range(10):
list1.append(random.randint(50, 300))
new_list = list1[:]
for x in list1:
if x not in new_list:
new_list.append(x)
new_list.sort(reverse=True)
print(new_list)
2.利用列表推导式, 完成以下需求
a. 生成一个存放1-100中各位数为3的数据列表
结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
list2 = [x for x in range(1,101) if x % 10 == 3]
print(list2)
b. 利用列表推到是将 列表中的整数提取出来
例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
list3 = [True, 17, "hello", "bye", 98, 34, 21]
list4 = [x for x in list3 if type(x) == type(1)]
print(list4)
c.利用列表推导式 存放指定列表中字符串的长度
例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
list5 = ["good", "nice", "see you", "bye"]
list6 = [len(x) for x in list5]
print(list6)
3.已知代码如下,请回答出各个print的结果 并说明原因
nums = [17, 39, 28, 51]
nums2 = nums
nums2.pop()
print(len(nums)) # 这个结果是什么 请描述原因
"""
输出结果为 3
因为列表.pop()表示删除列表最后一个元素,所以len(nums2)会变为3,而nums2 = nums则会使两个列表
公用一个地址,nums2的变化会同样反馈在nums上
"""
numlist = [17, 22, 39, 58, [55, 43]]
nums3 = numlist.copy()
print(numlist is nums3) # 结果 原因是什么
"""
结果为 False
因为列表.copy()方法是复制原列表产生一个相同的新列表,这两个列表数据相同,但地址不同,
is 用于判断两个列表的地址是否相同,所以结果为False
"""
numlist[-1][0] = 99
print(nums3) # num3会不会发生变化
"""
会,copy是浅拷贝,numlist中的[55,43]元素是以地址的形式存储在列表中,所以copy复制后同样
以地址的形式存储在新列表中,所以对于两列表中[55,43]的改动会影响到彼此
"""
4.自己用代码实现列表相关方法的功能:count、index、extend、clear
# count方法
list7 = [1, 2, 3, 4, 5]
m, n = list7[0], 0
for x in list7:
if x == m:
n += 1
print(m,'出现了', n,'次')
# index方法
for x in range(len(list7)):
if list7[x] == m:
print(m,'在列表的下标为', x)
# extend
m = 'abc'
for x in m:
list7.append(x)
print(list7)
# clear
new_list7 = list7[:]
for x in new_list7:
list7.remove(x)
print(list7)