自定义函数twonums_sum(n, lst),在列表lst中查找是否有两数之和等于n,若有则返回两数的下标,否则返回-1。对于一个不包含重复数字的有序列表[1, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 18, 19, 20, 21, 29, 34, 54, 65],从键盘输入n,调用函数twonums_sum()输出满足条件的两个数的下标(找到一组即可且要求其中的一个数尽量小),若所有数均不满足条件则输出“not found”。
def twonums_sum(n, lst):
for i in range(len(lst)):
for j in range(len(lst)):
if lst[i]+lst[j] == int(n):
return (i, j)
else:
return 'not found'
n = input('please input n: ')
lst = [1, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 18, 19, 20, 21, 29, 34, 54, 65]
print(twonums_sum(n, lst))