我是靠谱客的博主 悦耳马里奥,最近开发中收集的这篇文章主要介绍day5-列表作业(2),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1.已知一个数字列表,求列表中心元素。

nums = [23, 9, 34, 5, 15, 71]
cen_list = len(nums)//2
if len(nums) % 2:
    print(nums[cen_list])
else:
    print(nums[cen_list-1], nums[cen_list])

2.已知一个数字列表,求所有元素和。

3.已知一个数字列表,输出所有奇数下标元素。

4.已知一个数字列表,输出所有元素中,值为奇数的元素。

5.已知一个数字列表,将所有元素乘二。

例如:nums = [1, 2, 3, 4] —> nums = [2, 4, 6, 8]

nums = [23, 9, 34, 5, 15, 71]
for i in range(len(nums)):
    nums[i] *= 2
else:
    print(nums)

6.有一个长度是10的列表,数组内有10个人名,要求去掉重复的

例如:names = [‘张三’, ‘李四’, ‘大黄’, ‘大黄’, ‘张三’, ‘张三’, ‘张三’] -> names = [‘张三’, ‘李四’, ‘大黄’]

names = ['张三', '李四', '大黄', '大黄', '张三', '张三', '张三']
temp_names = []
for name in names:
    if name not in temp_names:
        temp_names.append(name)
else:
    names = temp_names
    print(names)

7.用一个列表来保存一个节目的所有分数,求平均分数(去掉一个最高分,去掉一个最低分,求最后得分)

nums = [23, 9, 34, 5, 15, 71]
print((sum(nums)-max(nums)-min(nums))/(len(nums)-2))

8.有两个列表A和B,使用列表C来获取两个列表中公共的元素

例如: A = [1, ‘a’, 4, 90] B = [‘a’, 8, ‘j’, 1] --> C = [1, ‘a’]

A = [1, 'a', 4, 90]
B = ['a', 8, 'j', 1]
C = []
for a in A:
    if a in B:
        C += [a]
else:
    print(C)

9.*有一个数字列表,获取这个列表中的最大值.(注意: 不能使用max函数)

例如: nums = [19, 89, 90, 600, 1] —> 600

10.*获取列表中出现次数最多的元素

例如:nums = [1, 2, 3,1,4,2,1,3,7,3,3] —> 打印:3

nums = [1, 2, 3, 4, 4, 4, 3, 3, ]
# fil_nums用来记录去掉重复值后的列表
fil_nums = []
# cnt_li 用来记录每个元素出现次数,此处其实也可以用一个数组存储或用复数形式存储
cnt_li = []
# out_li用来记录输出的列表
out_li = []
# 填充fil_nums
for num in nums:
    if num not in fil_nums:
        fil_nums += [num]
else:
    print('去重后的列表为: ', fil_nums)
    print('去重完毕'.center(40,'='))
# 遍历去重后的列表,并与原始列表进行对比,记录每个元素出现次数,记录到cnt_li中
for num in fil_nums:
    cnt = 0
    for hh in nums:
        if num == hh:
            cnt += 1
    cnt_li += [cnt]     # 将元素对应出现次数插入列表
else:
    print('原始列表', 't', fil_nums,)
    print('元素出现次数' 't', cnt_li)
    print('获取元素出现次数完毕'.center(40,'='))
# 对出现次数列表进行处理,获取出现次数最多元素
for i in range(1, len(cnt_li)):
    # 如果出现次数大于前者,则将结果列表清空后,添加数据
    if cnt_li[i] > cnt_li[i-1]:
        out_li = []
        out_li.append(fil_nums[i])
    # 如果出现次数相等,则直接在结果列表中,添加数据
    elif cnt_li[i] == cnt_li[i-1]:
        out_li.append(fil_nums[i])
else:
    print('出现最多的元素是: ', out_li)
    print('执行完毕'.center(40, '='))

最后

以上就是悦耳马里奥为你收集整理的day5-列表作业(2)的全部内容,希望文章能够帮你解决day5-列表作业(2)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部