作业1:有一堆硬币,每次只能拿一个或者两个,求最少多少次可以拿完硬币
[10, 8, 5, 3, 27, 99]
num = 0
sl = [10, 8, 5, 3, 27, 99]
for i in sl:
a = i % 2
if a == 0:
num = i // 2 + num
else:
num = i // 2 + num + 1
print("需要取的次数是",(num))
作业2:如果两个素数之差为2,这样的两个素数就叫作"孪生数",找出100以内的所有"孪生数".
num = []
for i in range(2, 101):
flag = True
for j in range(2, i):
if i % j == 0:
flag = False
break
if flag:
num.append(i)
index = 0
print(num)
while index < len(num) - 1:
first = num[index]
second = num[index + 1]
if second - first == 2:
print(f"{first}和{second}之间是孪生素数")
index += 1
作业4:将list中的重复数据去重,至少使用两种方案
>>>a=[1,2,34,2,1,4,2,2,4,3]
>>> type(a)
<class 'list'>
>>> set(a)
{1, 2, 3, 34, 4}
作业5:两个列表进行合并操作
>>>a=[1,2,34,2,1,4,2,2,4,3]
>>> type(a)
<class 'list'>
>>>b=['张天乐','田家齐','徐辉','姬凯']
>>> type(b)
<class 'list'>
>>> a.extend(b)
>>> a
[1, 2, 34, 2, 1, 4, 2, 2, 4, 3, '张天乐', '田家齐', '徐辉', '姬凯']
作业6: 使用列表判断一个列表是否在另外一个列表中
a = [4892,64,3,4,2,6,7]
b = [3,435,2,4]
j = list(set(a).intersection(set(b)))
print(j)
作业7:列表的反转 列表的排序
反转
>>>b=['张天乐','田家齐','徐辉','姬凯']
>>> type(b)
<class 'list'>
>>> b.reverse()
>>> b
['姬凯', '徐辉', '田家齐', '张天乐']
排序
>>> a=[1,4,6,3,7,9,4,5,3,]
>>> a
[1, 4, 6, 3, 7, 9, 4, 5, 3]
>>> a.sort()
>>> a
[1, 3, 3, 4, 4, 5, 6, 7, 9]