Day2-[滑动窗口]你给我领悟
admin
2024-01-29 09:00:46
0

代码随想录算法训练营Day2

977, 有序数组的平方

给了提示双指针,一遍过芜湖,不多解释.

class Solution:def sortedSquares(self, nums: List[int]) -> List[int]:# 提示two pointers 双指针# Constraints: nums非空,inta,b = 0,len(nums) - 1res = []while a <= b:if abs(nums[a]) >= abs(nums[b]):res.append(nums[a] ** 2)a += 1elif abs(nums[a]) < abs(nums[b]):res.append(nums[b] ** 2)b -= 1return res[::-1]# TC:O(N)# SC:O(N)

209, 长度最小的子数组

for循环指针终止位置, while sum(nums[a:b]) >= target更新窗口起始位置的指针, a += 1.

第一遍O(N^2)超时,第二遍sum(nums[a:b])超时

sum(nums[a:b])超时解法

# 超时解法
class Solution:def minSubArrayLen(self, target: int, nums: List[int]) -> int:if sum(nums) < target:return 0windowLen = len(nums)a = 0for b in range(1,len(nums)+1):  # for循环标记的是终止位置while sum(nums[a:b]) >= target:# print(a,b,nums[a:b])windowLen = min(b - a, windowLen)a += 1return windowLen用sum(nums[a:b])也会超时

正确解法

class Solution:def minSubArrayLen(self, target: int, nums: List[int]) -> int:if sum(nums) < target:return 0windowLen = len(nums)a = 0sumL = 0for b in range(1,len(nums)+1):  # for循环标记的是终止位置sumL += nums[b-1]while sumL >= target:# print(a,b,nums[a:b])windowLen = min(b - a, windowLen)sumL -= nums[a]a += 1return windowLen# TC:O(N)# SC:O(1)

请问一下, 209.长度最小的子数组,使用滑动窗口,时间复杂度O(N)大概能想明白;best case是sum(nums) == target,只需要for循环求一次累加,时间复杂度还是O(N);那worst case是什么情况?

比较容易困惑的点在于“移动指针a的次数”,因为每次移动都需要比较sumL >= target,来决定是否要 pop, 所以很多人会认为worst case time complexity 是 O(kn),其实不然。因为当你这一次pop了k个数以后,不会再对这k个数进行操作.

换一种角度看,因为push函数里的while循环里本质上是pop出不可能的candidate,而每个数只会被pop一次。

因此,从整个array的角度来看这个while的循环条件最多只会比较2n次(考虑到会有一次比较不成立所以多考虑一次),因此复杂度为O(n)。Example:比如数组里所有元素都是target,第一次sumL >= target成立并删除元素,第二次sumL >= target不成立进入下一个b的循环.这样是O(2N).

59, 螺旋矩阵II

不太会,再想想

相关内容

热门资讯

原创 4... 写在文章前的声明:在本文之前的说明:本文中所列的投资信息,只是一个对基金资产净值进行排行的客观描述,...
胜宏科技港股大涨49% 做完英... 记者 陈月芹 4月21日,全球AI算力板龙头胜宏科技(02476.HK)登陆港交所,上市首日股价大涨...
永赢基金:聚焦“科技新锐”,科... 数据来源:Wind,时间统计区间为2025/1/1-2026/4/21,指数过往表现不预示未来,不构...
五大阅读趋势显现!当当网发布2... 在第31个世界读书日即将来临之际及首个全民阅读活动周期间,当当网正式发布2026国民阅读洞察报告。 ...
业绩逐季回暖 老百姓大药房一季... 上证报中国证券网讯(记者 夏子航)4月22日晚,老百姓大药房发布2025年年报和2026年一季报。今...
中国20强城市大洗牌:苏州接近... 中国的城市经济竞争格局一直在变化,每年发布的GDP数据都会对城市经济实力进行重新排列。2025年榜又...
直击金宏气体股东会:预期年内氦... 《科创板日报》4月22日讯(记者 郭辉)金宏气体日前举行2025年度股东大会。会上该公司审议了公司年...
5月1日起,俄据悉将叫停哈萨克... 据行业消息人士透露,俄罗斯将于5月1日起停止经友谊管道转运哈萨克斯坦输往德国的石油,相关调整计划已送...
深化具身智能生态布局 京东携手... 4 月 22 日,京东与国内消费级人形机器人头部企业松延动力正式达成三年期战略合作。双方将围绕产品研...
原创 帮... 先问你一个问题,美伊停火今晚到期,按常理避险情绪该升温,黄金应该涨吧?结果恰恰相反——原油涨了,黄金...
300295、600889,将... 三六五网、南京化纤,将被*ST。 公司股票自4月23日开市起停牌一天,于4月24日开市起复牌并实施退...
能源大变天!外媒:羡慕中国的石... 这一次油价突破 110 美元的能源危机,着实魔幻。如果放在十年前,没人会相信中国能在这场风波中获利,...
黄金涨跌两难,现在还能上车吗? 中新网4月22日电(记者 左雨晴) 四月以来,美伊局势反复拉扯,美联储降息预期一变再变。黄金价格在4...
“我身体健康”,库克现身员工大... 当地时间4月21日,受苹果官宣CEO换届影响,公司股价盘中下探超2%,总市值失守4万亿美元关口,收盘...
库克留下一个悬念 工程师能否拯救创新节奏? 听筒Tech(ID:tingtongtech)原创 文 | 赵 森 ...
探索消费信贷与社交支付深度融合... 腾讯这一金融产品再添新功能,4月19日,北京商报记者注意到,微信分付灰度测试转账功能引发热议,在向微...
土耳其主要银行股指早盘下跌2% 每经AI快讯,4月20日,土耳其主要银行股指早盘下跌2%。 每日经济新闻
好用的OTA代运营源头厂家 在如今竞争激烈的酒旅行业中,OTA代运营服务成为了众多酒店、民宿提升竞争力的关键。但市场上的代运营厂...
成都五一出游全国热门第三 “五一”假期临近,同程旅行最新发布的《2026“五一”旅行趋势报告》显示,今年“五一”期间成都同时位...