LeetCode-239 Sliding Window Maximum
题目描述 Given an array?nums,there is a sliding window of size?k?which is moving from the very left of the array to the very right. You can only see the?k?numbers in the window. Each time the sliding window moves right by one position. Return the max sliding window. ? 题目大意 给定一个数组,以及一个大小为k的窗口,要求将当前位置的窗口内的最大值保存下来,窗口每次向后移动一个位置。 ? 示例 E1 ? 解题思路 最简单的方法是,用multiset保存窗口内的数值,由于multiset有序,因此set的最后一个位置保存了set中的最大值,因此每次滑动窗口只需要更新窗口内的数字,将最后一个位置的数值存入结果中即可。 ? 复杂度分析 时间复杂度:O(N^2) 空间复杂度:O(N) ? 代码 class Solution { public: vector<int> maxSlidingWindow(vector<int>& nums,int k) { int n = nums.size(),fir = 0,sec = 0; multiset<int> win; vector<int> res; if(n == 0) return res; // 将前k个数字保存到set中 for(int i = 0; i < k; ++i) { win.insert(nums[i]); } // 将前k个数字的最大值存入结果中 res.push_back(*(win.rbegin())); // 依次访问之后的数字,更新set,并记录最大值到结果中 for(int i = k; i < n; ++i) { win.erase(win.find(nums[i - k])); win.insert(nums[i]); res.push_back(*(win.rbegin())); } return res; } }; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- windows – 使用托管服务帐户运行命令?
- botframework – Microsoft Bot Framework:例外:数据已更
- windows – BSOD后无法访问NTFS文件. chkdsk无法察觉腐败?
- windows缓冲区溢出
- windows – 启动应用程序后将控制权返回给cmd.exe
- Windows Phone 8.1:使用IList变量的C#回调无法转换为IVect
- 什么是Windows Fabric以及如何在其中托管服务?
- 如何使用Windows PC调试ios.iphone的webite
- Windows应用程序 – 安装.appx而不受信任的证书?
- R在Windows上:字符编码地狱