劍指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
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章