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]
nums = [70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
new_nums = []
for item in nums:
if item not in new_nums:
new_nums.append(item)
new_nums.sort(reverse=True)
print(new_nums)
2.利用列表推导式, 完成以下需求
a. 生成一个存放1-100中各位数为3的数据列表
结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
list1 = [x for x in range(1, 101) if x % 10 == 3]
print(list1)
b. 利用列表推到是将 列表中的整数提取出来
例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
list2 = [True, 17, "hello", "bye", 98, 34, 21]
new_list2 = [x for x in list2 if type(x) == int]
print(new_list2)
c.利用列表推导式 存放指定列表中字符串的长度
例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
list3 = ["good", "nice", "see you", "bye"]
new_list3 = [len(x) for x in list3]
print(new_list3)
3.已知代码如下,请回答出各个print的结果 并说明原因
nums = [17, 39, 28, 51]
nums2 = nums
nums2.pop()
print(len(nums)) # 这个结果是什么 请描述原因
'''
结果是:3
因为nums2 = nums是直接赋值的,两个列表的数据和地址都相同,因此,对nums删除最后一个元素,num也会删除最后一个元素
最终nums = [17, 39, 28]
长度为3
'''
numlist = [17, 22, 39, 58, [55, 43]]
nums3 = numlist.copy()
print(numlist is nums3) # 结果 原因是什么
'''
结果是False,因为此处nums3是对numlist进行copy,二者的数据是相同的,但是地址不同
数据1 is 数据2 - 判断两个数据是否相等(判断数据的地址)
因此是False
'''
numlist[-1][0] = 99
print(nums3) # num3会不会发生变化
'''
会
'''
4.自己用代码实现列表相关方法的功能:count、index、extend、clear
# count-统计指定元素在列表中出现的次数或者个数
nums = [17, 39, 28, 51, 17, 28, 45]
item = int(input("请输入列表中的任意一个元素:"))
sum1 = 0
for x in nums:
if item == x:
sum1 += 1
print(sum1)
# index - 获取指定元素在列表中的下标(0~长度-1)
nums = [17, 39, 28, 51, 17, 28, 45]
item = int(input("请输入列表中的任意一个元素:"))
for x in range(len(nums)):
if nums[x] == item:
print(x)
break
# extend- 将序列中所有的元素都添加到列表中
nums = [17, 39, 28, 51, 17, 28, 45]
new_nums = 'abc'
nums.append(list(new_nums)[0])
nums.append(list(new_nums)[1])
nums.append(list(new_nums)[2])
print(nums)
# clear- 清空列表(删除列表中所有的元素)
nums = [17, 39, 28, 51, 17, 28, 45]
nums = []
print(nums)