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]
from random import randint
list1 = []
for x in range(10):
num = randint(50, 300)
list1.append(num)
print(list1)
list1 = list(set(list1))
print(list1)
list1.sort(reverse=True)
print(list1)
2.利用列表推导式, 完成以下需求
a. 生成一个存放1-100中个位数为3的数据列表
结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
list1 = [x for x in range(100) if x % 10 == 3]
print(list1)
b. 利用列表推导式将列表中的整数提取出来
例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
list1 = [True, 17, "hello", "bye", 98, 34, 21]
list2 = [x for x in list1 if type(x) == type(1)]
print(list2)
c.利用列表推导式 存放指定列表中字符串的长度
例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
list1 = ["good", "nice", "see you", "bye"]
list2 = [len(x) for x in list1]
print(list2)
3.已知代码如下,请回答出各个print的结果 并说明原因
nums = [17, 39, 28, 51]
nums2 = nums
nums2.pop()
print(len(nums)) # 这个结果是什么 请描述原因
numlist = [17, 22, 39, 58, [55, 43]]
nums3 = numlist.copy()
print(numlist is nums3) # 结果 原因是什么
numlist[-1][0] = 99
print(nums3) # num3会不会发生变化
问题1:print(len(nums))的结果为:3
nums2 = nums,它们地址是相同的,nums2.pop()去掉nums2中最后一个元素,nums1中最后一个元素也被去掉了,所以说最后判断nums的长度的时候就为3。
问题2:print(numlist is nums3)的结果为:False
num3为numlist的复制,数据相同,地址不同。
问题3:num3会变化,因为这是浅拷贝。
4.自己用代码实现列表相关方法的功能:count、index、extend、clear
# count
scores = [90, 89, 89, 70, 100, 100, 23, 100, 89, 89]
num = int(input('请输入scores列表中其中一个数:'))
y = 0
for x in scores:
if x == num:
y += 1
print(y)
# index
song = ['晴天', '大不了重头再来', '只因你太美', '成都', '晴天', '阳光总在风雨后']
song_name = input('请输入列表中一首歌:')
for index, item in enumerate(song):
if item == song_name:
print(index)
# clear
list1 = [1, 2, 3, 4]
del list1[:]
print(list1)
# extend
list1 = [1, 2, 3, 4, 5]
list2 = 'abc'
for x in list2:
list1.append(x)
print(list1)