1. 基础题
-
已知一个数字列表,打印列表中所有的奇数
-
已知一个数字列表,打印列表中所有能被能被3整除但是不能被2整除的数
-
已知一个数字列表,计算所有偶数的和
-
已知一个数字列表,统计列表中十位数是
1
的数的个数 -
已知一个列表,获取列表中下标为奇数是所有元素(从0开始的下标值)
例如: list1 = [10, 20, 5, 34, 90, 8]
结果:[20, 34, 8]
-
已知一个数字列表,将列表中所有元素乘以2
例如: nums = [10, 3, 6, 12] 乘2后: nums = [20, 6, 12, 24]
-
已知一个列表,获取列表的中心元素
例如:nums = [10, 2, 6, 12] -> 中心元素为: 2和6
nums = [10, 2, 6, 12, 10] -> 中心元素为:6
-
已知一个列表,获取列表中所有的整型元素
例如:list1 = [10, 1.23, ‘abc’, True, 100, ‘hello’, ‘20’, 5]
结果是: [10, 100, 5]
# 1已知一个数字列表,打印列表中所有的奇数 lists = [1, 2, 3, 4, 5, 6, 7] list_odd = [i for i in lists if i % 2 == 1] print(list_odd) # 2已知一个数字列表,打印列表中所有能被能被3整除但是不能被2整除的数 lists = [1, 3, 6, 7, 9, 20, 10, 17, 60] result = [i for i in lists if i % 2 != 0 and i % 3 == 0] print(result) # 3已知一个数字列表,计算所有偶数的和 lists = [1, 2, 3, 4, 5, 6, 7] list_even = [i for i in lists if i % 2 == 0] print(sum(list_even)) # 4已知一个数字列表,统计列表中十位数是1的数的个数 lists = [1, 3, 6, 7, 9, 10, 10, 17, 60, 11] counts = len([i for i in lists if i % 100 // 10 == 1]) print(counts) # 5已知一个列表,获取列表中下标为奇数是所有元素(从0开始的下标值) list_odd_index = [lists[i] for i in range(1, len(lists), 2)] print(list_odd_index) # 6已知一个列表,获取列表的中心元素 nums = [10, 2, 6, 3, 12, 10] a = len(nums) if a % 2 == 0: print(nums[a // 2], nums[a // 2 - 1]) else: print(nums[a // 2]) # 7已知一个列表,获取列表中所有的整型元素 lists = [10, 1.23, 'abc', True, 100, 'hello', '20', 5] result = [i for i in lists if type(i) == int] print(result)
2. 进阶题
-
定义一个列表保存多个学生的分数,删除列表中所以低于60分的值
例如: scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66] 删除后: scores = [60, 89, 99, 80, 71, 66]
-
已知一个列表保存了多个学生的姓名,要求去掉列表中重复的名字
例如:names = [‘小明’, ‘张三’, ‘李四’, ‘张三’, ‘张三’, ‘小明’, ‘王五’, ‘王五’]
去重后:names = [‘小明’, ‘张三’, ‘李四’, ‘王五’]
-
已知一个数字列表,获取列表中值最大的元素 (不能使用max函数)
-
已知两个有序列表(列表中的元素已经按照从小到大的方式排好序),要求合并两个列表,合并后元素还是从小到大排序
例如: 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, 45, 67, 91] 输入: 50 -> list1 = [10, 23, 45, 50, 67, 91]
# 1定义一个列表保存多个学生的分数,删除列表中所以低于60分的值
scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66]
# 方法1:
new_scores = [x for x in scores if x >= 60]
print(new_scores)
# 方法2:
new_scores = scores.copy()
for x in new_scores:
if x < 60:
print(f'x:{x}')
new_scores.remove(x)
print(new_scores)
# 方法3(倒着删):
scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66]
for x in range(len(scores)-1, -1, -1):
if scores[x] < 60:
del scores[x]
print(scores)
# 2已知一个列表保存了多个学生的姓名,要求去掉列表中重复的名字
names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五']
names1 =[]
for i in names:
if i not in names1:
names1.append(i)
print(names1)
# 3已知一个数字列表,获取列表中值最大的元素 (不能使用max函数)
l_nums = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66,100]
max = l_nums[0]
for i_num in l_nums[1:]:
if i_num > max:
max = i_num
print(max)
# 4已知两个有序列表(列表中的元素已经按照从小到大的方式排好
list1 = [10, 23, 39, 41, 52, 55, 80]
list2 = [9, 38, 55, 70]
list3 = []
while list2 != [] and list1 != []:
if list1[0] > list2[0]:
list3.append(list2.pop(0))
else:
list3.append(list1.pop(0))
list3.extend(list1+list2)
print(list3)
# 5已知一个有序数字列表(从小到大),输入任意一个数字,将输入的数字插入列表中,要求插入后列表仍然保持从小到大排序的关系
list1 = [10, 23, 45, 50, 67, 91]
num = 50
for i in range(len(list1)):
if list1[i] >= num:
list1.insert(i, num)
break
print(list1)