有一堆硬币,每次只能拿一个或者两个,求最少多少次可以拿完硬币
[10, 8, 5, 3, 27, 99]
num = 0
coins = [10, 8, 5, 3, 27, 99]
for c in coins:
if c % 2 == 0:
num += c // 2
else:
num += c // 2 + 1
print(f"用户最少需要{num}次,可以拿完硬币")
如果两个素数之差为2,这样的两个素数就叫作"孪生数",找出100以内的所有"孪生数".
temp = []
for i in range(1 , 101) :
for j in range(2 , i) :
if i % j == 0 :
break
else :
temp.append(i)
for i in range(0 , len(temp) + 1) :
if i + 1 == len(temp) :
break
if temp[i + 1] - temp[i] == 2:
print(f"{temp[i]}和{temp[i + 1]}为一对孪生数")
给定一个列表,求最大值(不能使用系统api),求最小值,求平均值、求和
arr_max = arr[0]
arr_min = arr[0]
arr_sum = 0
for a in arr:
if a > arr_max:
arr_max = a
if a < arr_min:
arr_min = a
arr_sum += a
print(f"最大值是{arr_max}")
print(f"最小值是{arr_min}")
print(f"和是{arr_sum}")
print(f"平均值是{arr_sum / len(arr)}")
将list中的重复数据去重,至少使用两种方案
1
array = list(input("请输入一个数列:"))
temp = []
for i in array :
if i not in temp :
temp.append(i)
print(temp)
2
array = list(input("请输入一个数列:"))
#使用哈希表不能重复的特性
temp = list(set(array))
#因为哈希表无序,所以转换后需要进行排序
temp.sort()
print(temp)
两个列表进行合并操作
array_1 = list(input("请输入第一个列表:"))
array_2 = list(input("请输入第二个列表:"))
array_1.extend(array_2)
print(array_1)
使用列表判断一个列表是否在另外一个列表中
array_1 = list(input("请输入第一个列表:"))
array_2 = list(input("请输入第二个列表:"))
#定义一个判断值,用来表达不包含的情况
i = 1
for i in array_2 :
#如果array_2中有一个元素array_1中没有,则不包含,判断值置0
if i not in array_1 :
print("array_2不在array_1中")
i = 0
break
#i为1,则表示包含,为0表示不包含
if i :
print("array_2在array_1中")
列表的反转 列表的排序
array_1 = list(input("请输入列表:"))
#定义;列表容纳反转数列
array_2 = []
for i in array_1:
array_2.insert(0,i)
print(f"翻转后:{array_2}")
#冒泡排序
for i in range(len(array_1)):
for j in range(1, len(array_1) - i):
if array_1[j - 1] > array_1[j]:
array_1[j - 1], array_1[j] = array_1[j], array_1[j - 1]
print(f"排序后:{array_1}")
如何将0-10随机存入列表中
import random
#定义一个数组容纳
array= []
#写入10次随机数
for i in range(10) :
j = random.randint(1 , 10)
array.append(j)
print(array)
存在一个1~n的连续列表,在其中不小心重复了一个值,请找出这个重复值
[1,2,3,4,5]
res = 0
arr = [1, 4, 2, 3, 4, 5]
for i in range(0, len(arr)):
res ^= i ^ arr[i]
print(res)