作者推荐
map|动态规划|单调栈|LeetCode975:奇偶跳
本文涉及的基础知识点
C++算法:滑动窗口总结
单调双向队列 二叉树
题目
给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。
返回 滑动窗口中的最大值 。
示例 1:
输入:nums = [1,3,-1,-3,5,3,6,7], k = 3
输出:[3,3,5,5,6,7]
解释:
滑动窗口的位置 最大值
[1 3 -1] -3 5 3 6 7 3
1 [3 -1 -3] 5 3 6 7 3
1 3 [-1 -3 5] 3 6 7 5
1 3 -1 [-3 5 3] 6 7 5
1 3 -1 -3 [5 3 6] 7 6
1 3 -1 -3 5 [3 6 7] 7
示例 2:
输入:nums = [1], k = 1
输出:[1]
参数范围:
1 <= nums.length <= 105
-104 <= nums[i] <= 104
1 <= k <= nums.length
单调栈
时间复杂度😮(n)。
queMax中记录(i-k,i],如果i1 < i2,且nums[i1] <=nums[i2],那么i1无论如何都无法成为最大值。故可以淘汰i1,淘汰i1后,成降序排列。队首元素最大。
对queMax有三种操作。
操作一 | 队尾淘汰i1 |
操作二 | 队尾插入i2 |
操作三 | 队首删除i-k,由于操作二,queMax不会为空,所以无需判断是否为空。如果i-k已经被操作一淘汰,则不能删除。 |
代码
核心代码
class Solution { public: vectormaxSlidingWindow(vector & nums, int k) { int i = 0; std::deque queMax; vector vRet; for ( i = 0; i < k; i++) { while (queMax.size() && (nums[queMax.back()] <= nums[i])) { queMax.pop_back(); } queMax.emplace_back(i); } vRet.emplace_back(nums[queMax.front()]); for (; i < nums.size(); i++) { if (i - k == queMax.front()) { queMax.pop_front(); } while (queMax.size() && (nums[queMax.back()] <= nums[i])) { queMax.pop_back(); } queMax.emplace_back(i); vRet.emplace_back(nums[queMax.front()]); } return vRet; } };
测试用例
templatevoid Assert(const T& t1, const T& t2) { assert(t1 == t2); } template void Assert(const vector & v1, const vector & v2) { if (v1.size() != v2.size()) { assert(false); return; } for (int i = 0; i < v1.size(); i++) { Assert(v1[i], v2[i]); } } int main() { vector nums; int k; { Solution sln; nums = { 1, 3, -1, -3, 5, 3, 6, 7 }, k = 3; auto res = sln.maxSlidingWindow(nums, k); Assert(vector { 3,3,5,5,6,7 }, res); } { Solution sln; nums = { 1 }, k = 1; auto res = sln.maxSlidingWindow(nums, k); Assert(vector { 1 }, res); } //CConsole::Out(res); }
2023年3月二叉树
用多键二叉树(红黑树)mulset记录滑动窗口中的数,由于二叉树默认是升序排列,所以最后一个元素,就是最大值。由于二叉树的插入、删除的时间复杂度是O(logn),故总时间复杂度是O(nlogn) 。
class Solution { public: vectormaxSlidingWindow(vector & nums, int k) { int i = 0; std::multiset setNums; for (; i + 1 < k; i++) { setNums.insert(nums[i]); } vector vRet; for (; i < nums.size(); i++) { setNums.insert(nums[i]); vRet.push_back(*setNums.rbegin()); auto it = setNums.find(nums[i + 1 - k]); setNums.erase(it); } return vRet; } };
2023年3月第二版
class Solution {
public:
vector maxSlidingWindow(vector& nums, int k) {
vector
vector vRet;
int iPos = 0;
for (int i = 0; i < nums.size(); i++)
{
while ( ( vValueIndex.size() > iPos ) && (nums[i] >= vValueIndex.back().first))
{
vValueIndex.pop_back();
}
vValueIndex.emplace_back(nums[i], i);
if (i + 1 >= k)
{
vRet.push_back(vValueIndex[iPos].first);
}
if (i + 1 - k == vValueIndex[iPos].second)
{
iPos++;
}
}
return vRet;
}
};
2023年8月版
class Solution{
public:
vector maxSlidingWindow(vector&nums, int k) {
m_c = nums.size();
//每k个元素用一组,vLeft各元素到组首的最大值,vRight各元素到组尾的最大值
vector vLeft(m_c), vRight(m_c);
int iMax = 0;
for (int i = 0; i < m_c; i++)
{
if (0 == i % k)
{
iMax = nums[i];
}
else
{
iMax = max(iMax, nums[i]);
}
vLeft[i] = iMax;
}
iMax = -100 * 1000;
for (int i = m_c-1;i >= 0 ; i-- )
{
if (0 == (i+1) % k)
{
iMax = nums[i];
}
else
{
iMax = max(iMax, nums[i]);
}
vRight[i] = iMax;
}
vector vRet;
for (int i = k-1; i < m_c; i++)
{
vRet.emplace_back( max(vRight[i-k+1], vLeft[i]));
}
return vRet;
}
int m_c;
};
扩展阅读
视频课程
有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771
如何你想快
速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176
相关
下载
想高屋建瓴的学习算法,请下载《喜缺全书算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653
我想对大家说的话 |
---|
闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。 |
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。 |
如果程序是一条龙,那算法就是他的是睛 |
测试环境
操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用C++ 实现。
猜你喜欢
- 12天前(希尔顿2021活动)希尔顿集团618盛夏大促开启
- 12天前(fender japan hybrid)Fender东京旗舰店盛大开幕在即,开售商品和店内服务提前揭晓
- 12天前(云南南博会展馆)旅居云南馆亮相第9届南博会
- 12天前(云南滇陇工程咨询有限公司)陇滇携手谋发展 文旅合作谱新篇
- 12天前(澳涞山庄见证北欧零碳到中国实践,世界十佳环境保护城市榜单发布)澳涞山庄见证北欧零碳到中国实践,世界十佳环境保护城市榜单发布
- 12天前(希尔顿集团2021年筹建的酒店)希尔顿集团两大重点项目亮相第四届上海旅游投资促进大会
- 12天前(星级饭店的发展困境)星级饭店转型之路:从市场逻辑到行业实践的深度探索
- 12天前(锦州新增两家国家aaa级旅游景区有哪些)锦州新增两家国家AAA级旅游景区
- 12天前(大连aaaaa景区)辽宁大连A级旅游景区应急救护水平整体跃升
- 12天前(阿斯塔纳航空属于哪个联盟)阿斯塔纳航空荣获Skytrax世界航空公司大奖,将继续助力中哈交流往来
网友评论
- 搜索
- 最新文章
- (2020广州车展哈弗)你的猛龙 独一无二 哈弗猛龙广州车展闪耀登场
- (哈弗新能源suv2019款)智能科技颠覆出行体验 哈弗重塑新能源越野SUV价值认知
- (2021款全新哈弗h5自动四驱报价)新哈弗H5再赴保障之旅,无惧冰雪护航哈弗全民电四驱挑战赛
- (海南航空现况怎样)用一场直播找到市场扩张新渠道,海南航空做对了什么?
- (visa jcb 日本)优惠面面俱到 JCB信用卡邀您畅玩日本冰雪季
- (第三届“堡里有年味·回村过大年”民俗花灯会活动)第三届“堡里有年味·回村过大年”民俗花灯会活动
- (展示非遗魅力 长安启源助力铜梁龙舞出征)展示非遗魅力 长安启源助力铜梁龙舞出征
- (阿斯塔纳航空公司)阿斯塔纳航空机队飞机数量增至50架
- (北京香港航班动态查询)香港快运航空北京大兴新航线今日首航
- (我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉)我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉
- 热门文章