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]
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.基础题
# 1.已知一个数字列表,打印列表中所有的奇数
list1=[1,45,23,564,27,47]
for i in list1:
if i % 2!=0:
print(i)
# 2.已知一个数字列表,打印列表中所有能被能被3整除但是不能被2整除的数
list1=[1,45,23,564,27,47]
for i in list1:
if i%3==0 and i %2!=0:
print(i)
# 3.已知一个数字列表,计算所有偶数的和
sum=0
list1=[1,45,23,564,27,47]
for i in list1:
if i %2 ==0:
sum+=i
print(sum)
# 4.已知一个数字列表,统计列表中十位数是`1`的数的个数
list1=[1,45,23,514,27,47,13,1219]
count=0
for i in list1:
if i%100//10==1:
count+=1
print(count)
# 5.已知一个列表,获取列表中下标为奇数是所有元素(从0开始的下标值)
# > 例如: list1 = [10, 20, 5, 34, 90, 8]
# > 结果:[20, 34, 8]
list2=[]
list1 = [10, 20, 5, 34, 90, 8]
for i in range(len(list1)):
if i %2 !=0:
list2.append(list1[i])
print(list2)
# 6.已知一个数字列表,将列表中所有元素乘以2
# > 例如: nums = [10, 3, 6, 12] 乘2后: nums = [20, 6, 12, 24]
nums = [10, 3, 6, 12]
nums1=[]
for i in nums:
nums1.append(i*2)
print(nums1)
# 7.已知一个列表,获取列表的中心元素
# > 例如:nums = [10, 2, 6, 12] -> 中心元素为: 2和6
# nums = [10, 2, 6, 12, 10] -> 中心元素为:6
# nums = [10, 2, 6, 12,10]
if len(nums)%2!=0:
print(nums[len(nums) // 2])
else:
print(nums[len(nums) // 2 - 1], 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]
list2=[]
for i in list1:
if type(i)==int:
list2.append(i)
print(list2)
# 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]
scores1=[]
for i in scores:
if i>60:
scores1.append(i)
print(scores1)
# 2.已知一个列表保存了多个学生的姓名,要求去掉列表中重复的名字
# > 例如:names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五']
# 去重后:names = ['小明', '张三', '李四', '王五']
names = ['小明', '张三', '李四', '张三', '张三', '小明', '王五', '王五']
names1=[]
for i in names:
if i not in names1:
names1.append(i)
print(names1)
# 3.已知一个数字列表,获取列表中值最大的元素 (不能使用max函数)
list=[16,23,99,52,34,46,62]
for i in range(len(list)):
for x in range(i,len(list)):
if list[i]>list[x]:
list[i],list[x]=list[x],list[i]
print(list[-1])
# 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]
list3=list1+list2
for i in range(len(list3)):
for x in range(i, len(list3)):
if list3[i]>list3[x]:
list3[i],list3[x]=list3[x],list3[i]
print(list3)
# 5.已知一个有序数字列表(从小到大),输入任意一个数字,将输入的数字插入列表中,要求插入后列表仍然保持从小到大排序的关系
# > 例如: list1 = [10, 23, 45, 67, 91]
# 输入: 50 -> list1 = [10, 23, 45, 50, 67, 91]
list1 = [10, 23, 45, 67, 91]
num=int(input('请输入数字:'))
list1.append(num)
for i in range(len(list1)):
for x in range(i, len(list1)):
if list1[i]>list1[x]:
list1[i],list1[x]=list1[x],list1[i]
print(list1)