列表作业

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

list1=[1,5,7,7,4,5,6]
a=0
for i in range(len(list1)):
    if i & 1:
        a+=1
    else:
    	print(list1[a-1],list1[a])

print(list1[a])


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

list1=[1,5,7,3,6,4,5]
sum=0
for i in list1:
    sum+=i
print(sum)

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

list1 = [1, 5, 7, 3, 6, 4, 5]
for i in range(1, len(list1), 2):
    print(list1[i])

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

list1 = [1, 5, 7, 3, 6, 4, 5]
for i in list1:
    if i & 1:
        print(i)

5.已知一个数字列表,将所有元素乘二。
例如:nums = [1, 2, 3, 4] —> nums = [2, 4, 6, 8]

list1 = [1, 5, 7, 3, 6, 4, 5]
lists = []
for i in list1:
    i *= 2
    lists.append(i)
    list1=lists
print(list1)
# 方法二
for i in range(len(list1)):
	nums[i]*=2
print(nums)
# 方法三
for i , j in enumerate(nums):
	nums[i]*=2
print(nums)

6.有一个长度是10的列表,数组内有10个人名,要求去掉重复的
例如:names = [‘张三’, ‘李四’, ‘大黄’, ‘张三’] -> names = [‘张三’, ‘李四’, ‘大黄’]

# 方法一
names = ['张三', '李四', '大黄', '张三', '11', '11', '15', '18', '35', '19']
names2=[]
for i in range(len(names) - 1, -1, -1):
    for j in range(len(names) - 1, i, -1):
        if names[i] == names[j]:
            del names[j]
print(names)
# 方法二
names1 = ['张三', '李四', '大黄', '张三', '11', '11', '15', '18', '35', '19']

for i in names1[:]:
    if names1.count(i)>1:
        names1.remove(i)

print(names1)

# 方法三
names = ['张三', '李四', '大黄', '张三', '11', '11', '15', '18', '35', '19']
names2=[]
for i in names:
    if i not in names2:
        names2.append(i)
print(names2)

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

grade = [1, 9, 3, 5, 6, 4]

grade.remove(max(grade))
grade.remove(min(grade))
print(len(grade))
print(sum(grade) / len(grade))

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 i in A:
    if i in B:
        c.append(i)
print(c)

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

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

nums = [1, 7, 3, 4, 15, 20, 1, 3]

for i in range(len(nums) - 1, -1, -1):
    for j in range(len(nums) - 1, i - 2, -1):
        if nums[i] > nums[j]:
            del nums[j]
print(nums)

# 方法二
nums = [1, 7, 3, 4, 15, 20, 1, 3]
max_num=nums[0]
for i in nums[1:]:
	if i>max_nums:
		max_num=i
print(max_num)

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

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

nums = [1, 2, 3, 1, 4, 2, 1, 3,7,3,3,7,7,7,7,7,7,5,5]
max_nums=0
for i in nums:
    count=nums.count(i)
    if count > max_nums:
        max_nums=count
new_num=[]
for j in nums:
    if nums.count(j) == max_nums and j not in new_num:
        new_num.append(j)
print(new_num)




猜你喜欢

转载自blog.csdn.net/weixin_44628421/article/details/108842832