day06列表作业

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)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值