Day-008 作业

1. 基础题

  1. 已知一个数字列表,打印列表中所有的奇数
nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
for i in nums:
    if i % 2 != 0:
        print(i, end=' ')

# 运行结果
'''
1 3 5 7 9 
'''
  1. 已知一个数字列表,打印列表中所有能被能被3整除但是不能被2整除的数
nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
for i in nums:
    if i % 3 == 0 and i % 2 != 0:
        print(i, end=' ')

# 运行结果
'''
3 9 
'''
  1. 已知一个数字列表,计算所有偶数的和
nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
sum = 0
for i in nums:
    if i % 2 == 0:
        sum += i
print(sum)

# 运行结果
'''
30
'''
  1. 已知一个数字列表,统计列表中十位数是1的数的个数
nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 17,14]
count = 0
for i in nums:
    if i // 10 % 10 == 1:
        count += 1
print(count)

# 运行结果
'''
3
'''
  1. 已知一个列表,获取列表中下标为奇数是所有元素(从0开始的下标值)

    例如: list1 = [10, 20, 5, 34, 90, 8]

    结果:[20, 34, 8]

list_1 = [10, 20, 5, 34, 90, 8]
list_2 = []
for i in range(len(list_1)):
    if i % 2 != 0:
        list_2.append(list_1[i])
print(list_2)

# 运行结果
'''
[20, 34, 8]
'''
  1. 已知一个数字列表,将列表中所有元素乘以2

    例如: nums = [10, 3, 6, 12] 乘2后: nums = [20, 6, 12, 24]

nums = [10, 3, 6, 12]
for i, j in enumerate(nums):
    nums[i] = j * 2
print(nums)

# 运行结果
'''
[20, 6, 12, 24]
'''
  1. 已知一个列表,获取列表的中心元素

    例如:nums = [10, 2, 6, 12] -> 中心元素为: 2和6

    ​ nums = [10, 2, 6, 12, 10] -> 中心元素为:6

# nums = [10, 2, 6, 12] # 中心元素为: 2 和 6
nums = [10, 2, 6, 12, 10] # 中心元素为: 6
if len(nums) % 2 == 0:
    print('中心元素为:', nums[len(nums)//2-1], '和', nums[len(nums)//2])
else:
    print('中心元素为:', nums[len(nums)//2])

# 运行结果
'''
中心元素为: 6
'''
  1. 已知一个列表,获取列表中所有的整型元素

    例如:list1 = [10, 1.23, ‘abc’, True, 100, ‘hello’, ‘20’, 5]

    ​ 结果是: [10, 100, 5]

list1 = [10, 1.23, 'abc', True, 100,  'hello', '20', 5]
list2 = []
for i in list1:
    if type(i) == int:
        list2.append(i)
print(list2)

# 运行结果
'''
[10, 100, 5]
'''

2. 进阶题

  1. 定义一个列表保存多个学生的分数,删除列表中所以低于60分的值

    例如: scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66] 删除后: scores = [60, 89, 99, 80, 71, 66]

方法一

scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66]
# scores_new = scores # 错误方法
scores_new = scores[:]
# scores_new = scores * 1
# scores_new = scores + []
# scores_new = scores.copy()
for i in scores_new:
    if i < 60:
        scores.remove(i)
print(scores)

# 运行结果
'''
[60, 89, 99, 80, 71, 66]
'''

方法二

scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66]
scores_new = []
for i in scores:
    if i >= 60:
        scores_new.append(i)
print(scores_new)

# 运行结果
'''
[60, 89, 99, 80, 71, 66]
'''

方法三

scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66]
for i in range(len(scores)-1,-1,-1):
    if scores[i] < 60:
        del scores[i]
print(scores)

# 运行结果
'''
[60, 89, 99, 80, 71, 66]
'''
  1. 已知一个列表保存了多个学生的姓名,要求去掉列表中重复的名字

    例如:names = [‘小明’, ‘张三’, ‘李四’, ‘张三’, ‘张三’, ‘小明’, ‘王五’, ‘王五’]

    ​ 去重后:names = [‘小明’, ‘张三’, ‘李四’, ‘王五’]

方法一

names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五']
for i in range(len(names)-1, 0, -1):
    for j in range(i-1, -1, -1):
        if names[i] == names[j]:
            del names[i]
            i -= 1
print(names)

# 运行结果
'''
['小明', '张三', '李四', '王五']
'''

方法二

names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五']
names_new = []
for i in names:
    if i not in names_new:
        names_new.append(i)
print(names_new)

# 运行结果
'''
['小明', '张三', '李四', '王五']
'''

方法三

names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五']
for i in range(len(names)):
    name = names.pop(0)
    if name not in names:
        names.append(name)
print(names)

# 运行结果
'''
['李四', '张三', '小明', '王五']
'''
  1. 已知一个数字列表,获取列表中值最大的元素 (不能使用max函数)
nums = [12, 41, 54, 11, 3, 52, 98, 100, 12]
max_num = 0
for i in nums:
    if i > max_num:
        max_num, i = i, max_num
print(max_num)

# 运行结果
'''
100
'''
  1. 已知两个有序列表(列表中的元素已经按照从小到大的方式排好序),要求合并两个列表,合并后元素还是从小到大排序

    例如: list1 = [10, 23, 39, 41, 52, 55, 80] list2 = [9, 38, 55, 70]

    合并后的结果: [9, 10, 23, 38, 39, 41, 52, 55, 55, 70, 80]

list1 = [10, 23, 39, 41, 52, 55, 80]
list2 = [9, 38,  55, 70]
list_new = []
while True:
    a = list1.pop(0)
    b = list2.pop(0)
    if a < b:
        list_new.append(a)
        list2.insert(0, b)
    else:
        list_new.append(b)
        list1.insert(0, a)
    if list1 == [] or list2 == []:
        break
list_new += list1 + list2
print(list_new)

# 运行结果
'''
[9, 10, 23, 38, 39, 41, 52, 55, 55, 70, 80]
'''
  1. 已知一个有序数字列表(从小到大),输入任意一个数字,将输入的数字插入列表中,要求插入后列表仍然保持从小到大排序的关系

    例如: list1 = [10, 23, 45, 67, 91] 输入: 50 -> list1 = [10, 23, 45, 50, 67, 91]

list1 = [10, 23, 45, 67, 91]
num = int(input(''))
for i in range(len(list1)):
    if num <= list1[i]:
        list1.insert(i, num)
        break
print(list1)

# 运行结果
'''
[10, 23, 45, 50, 67, 91]
'''
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值