1. 基础题
-
已知一个数字列表,打印列表中所有的奇数
nums = [12, 33, 67, 98, 20, 65, 78] for x in nums: if x % 2 != 0: print(x)
-
已知一个数字列表,打印列表中所有能被能被3整除但是不能被2整除的数
nums = [12, 33, 67, 98, 20, 65, 78] for x in nums: if x % 3 == 0 and x % 2 != 0: print(x)
3.已知一个数字列表,计算所有偶数的和
nums = [12, 33, 67, 98, 20, 65, 78]
sum1 = 0
for x in nums:
if x % 2 == 0:
sum1 += x
print(sum1)
4.已知一个数字列表,统计列表中十位数是1
的数的个数
nums = [12, 113, 67, 208, 20, 65, 78]
count = 0
for x in nums:
if x // 10 % 10 == 1:
count += 1
print(count)
5.已知一个列表,获取列表中下标为奇数是所有元素(从0开始的下标值)
例如: list1 = [10, 20, 5, 34, 90, 8]
结果:[20, 34, 8]
list1 = [10, 20, 5, 34, 90, 8]
result = [list1[index] for index in range(len(list1)) if index % 2 != 0]
print(result)
6.已知一个数字列表,将列表中所有元素乘以2
例如: nums = [10, 3, 6, 12] 乘2后: nums = [20, 6, 12, 24]
nums = [10, 3, 6, 12]
result = [x*2 for x in nums]
print(result)
7.已知一个列表,获取列表的中心元素
例如:nums = [10, 2, 6, 12] -> 中心元素为: 2和6
nums = [10, 2, 6, 12, 10] -> 中心元素为:6
nums = [10, 2, 6, 12]
if len(nums) % 2 == 0:
print('中心元素为:', nums[len(nums)//2-1], '和', nums[len(nums)//2])
else:
print('中心元素为:', nums[len(nums)//2])
8.已知一个列表,获取列表中所有的整型元素
例如:list1 = [10, 1.23, ‘abc’, True, 100, ‘hello’, ‘20’, 5]
结果是: [10, 100, 5]
list1 = [10, 1.23, 'abc', True, 100, 'hello', '20', 5]
result = [x for x in list1 if type(x) == 'int']
print(result)
2. 进阶题
-
定义一个列表保存多个学生的分数,删除列表中所以低于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] new_scores = [] for x in scores: if x >= 60: new_scores.append(x) print(new_scores)
-
已知一个列表保存了多个学生的姓名,要求去掉列表中重复的名字
例如:names = [‘小明’, ‘张三’, ‘李四’, ‘张三’, ‘张三’, ‘小明’, ‘王五’, ‘王五’]
去重后:names = [‘小明’, ‘张三’, ‘李四’, ‘王五’]
names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五'] new_names = [] for x in names: if x not in new_names: new_names.append(x) print(new_names)
-
已知一个数字列表,获取列表中值最大的元素 (不能使用max函数)
nums = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66]
max_num = nums[0]
for x in nums:
if x > max_num:
max_num = x
print('列表中值最大的元素:', max_num)
4.已知两个有序列表(列表中的元素已经按照从小到大的方式排好序),要求合并两个列表,合并后元素还是从小到大排序
例如: 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]
new_list = list1 + list2
new_list.sort()
print(new_list)
5.已知一个有序数字列表(从小到大),输入任意一个数字,将输入的数字插入列表中,要求插入后列表仍然保持从小到大排序的关系
例如: list1 = [10, 23, 45, 67, 91] 输入: 50 -> list1 = [10, 23, 45, 50, 67, 91]
list1 = [10, 23, 45, 67, 91]
num = int(input('请输入一个数:'))
if num > list1[-1]:
list1.append(num)
else:
for index in range(len(list1)):
if list1[index] > num:
list1.insert(index, num)
break
print(list1)