发布于2019-08-22 17:39 阅读(1056) 评论(0) 点赞(0) 收藏(5)
输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。
如果有多对的数字的和等于s,则输出任意一对即可。
样例:
输入:数组{1,2,4,7,11,15}和数字15
输出:4和11
首先可以想到
想想更好的算法,我们可以在数组中先选择两个数字,如果两数之和大于s,我们就希望两个数字可以小一点。再结合递增排序,就可以得出
class Solution:
def FindNumbersWithSum(self, array, tsum):
# write code here
if not array:
return []
first = 0
last = len(array)-1
res = []
while first < last:
if array[first] + array[last] == tsum:
res.append([array[first], array[last]])
first += 1
last -= 1
elif array[first] + array[last] < tsum:
first += 1
else:
last -= 1
# 牛客网上要求返回乘积最小的一对,因此要做比较
if res:
index = 0
product = res[0][0] * res[0][1]
for i in range(len(res)):
if res[i][0] * res[i][1] <= product:
product = res[i][0] * res[i][1]
index = i
return res[index]
return []
输入一个正数s,打印出所有和为s的连续正数序列(至少含有两个数)。
样例:
输入:15
输入:[[1,2,3,4,5],[4,5,6],[7,8]]
沿用上一题的思路:
class Solution:
def FindContinuousSequence(self, tsum):
# write code here
if tsum < 3: return []
small = 1
big = 2
res = []
while small < big:
temp_sum = ( small+big ) * (big - small + 1) / 2
if temp_sum == tsum:
# 注意range的范围不要写错
res.append(list(range(small,big+1)))
small += 1
elif temp_sum > tsum:
small += 1
else:
big += 1
return res
作者:皇后娘娘别惹我
链接:https://www.pythonheidong.com/blog/article/53215/7290a12faf6fc0d5a72c/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!
列表(0)
装饰器(0)
python(1)
python学习教程(0)
类(0)
pandas(0)
文件操作(0)
python小游戏源码下载(17)
web表白小程序(8)
多线程(0)
爬虫(0)
python表白小程序(2)
装饰器(0)
python(1)
面试题(2)
python学习教程(0)
类(0)
pandas(0)
文件操作(0)
python小游戏源码下载(17)
web表白小程序(8)
多线程(0)
爬虫(0)
python表白小程序(2)