剑指offer面试题57 - II. 和为s的连续正数序列(双指针)(滑动窗口)

题目描述

输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。
序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。

在这里插入图片描述

思路

详见链接

代码

class Solution:
	def findContinuousSequence(self,target:int)->List[List[int]]:
		i, j, res = 1, 2, []
		while j <= target//2 + 1:
			cur_sum = sum(list(range(i,j+1)))
			if cur_sum < target:
				j += 1
			elif cur_sum > target:
				i += 1
			else:
				res.append(list(range(i,j+1)))
				j += 1
		return res
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章