1.有一堆硬币,每次只能拿一个或者两个,求最少多少次可以拿完硬币
[10, 8, 5, 3, 27, 99]
a = [10, 8, 5, 3, 27, 99]
sum = 0
for i in a:
if i % 2 == 1:
sum += (i // 2 + 1)
else:
sum += (i // 2)
print(f"最少{sum}次可以拿完硬币")
2.如果两个素数之差为2,这样的两个素数就叫作"孪生数",找出100以内的所有"孪生数".
a = []
for i in range(2,101):
flag = True
for j in range(2, i // 2 + 2):
if i % j == 0:
flag = False
break
while flag:
a.append(i)
break
b = 1
print("100以内的孪生数:")
while b < len(a):
if a[b] - a[b - 1] == 2:
print(f"{a[b - 1]},{a[b]} ", end="")
b += 1
3.给定一个列表,求最大值(不能使用系统api),求最小值,求平均值、求和
i = 1
a = [10, 8, 5, 3, 27, 99]
a_sum = a[0]
while i < len(a):
if a[i] > a[i - 1]:
a_max = a[i]
elif a[i] < a[i - 1]:
a_min = a[i]
a_sum += a[i]
i += 1
print(f"最大值是{a_max}")
print(f"最小值是{a_min}")
print(f"和是{a_sum}")
print(f"平均值是{a_sum / len(a)}")
4.将list中的重复数据去重,至少使用两种方案
#方法一
a = [10, 8, 5, 3, 27, 99, 3, 10, 29, 10]
a = list(set(a))
print(a)
#方法二
b = []
for i in a:
if i not in b:
b.append(i)
a = b
print(a)
5.两个列表进行合并操作
a = [1, 2, 3, 4, 5, 6, 7, ]
b = [10, 9, 8, 7, 4, 1]
a.extend(b)
print(a)
6.使用列表判断一个列表是否在另外一个列表中
a = [1, 2, 3, 4, 5, 6, 7, ]
b = [1, 2, 3, 4, 5]
num = 0
for i in a:
for j in b:
if j == i:
num += 1
if num == len(b):
print("列表b在列表a中")
7.列表的反转 列表的排序
a = [1,98, 2, 3, 10, 8,19,4, 5, 6, 7]
a.reverse()
print(a)
a.sort()
print(a)
8.如何将0-10随机存入列表中
import random
my_list = []
for i in range(10):
my_list.append(random.randint(0, 10))
print(my_list)
9.存在一个1~n的连续列表,在其中不小心重复了一个值,请找出这个重复值 [1,2,3,4,5]
a = [1, 2, 3, 4, 5, 6, 5]
for i in a:
if a.count(i) == 2:
print(f"重复值:{i}")
break