滑动窗口的最大值

题目:给定一个数组和滑动窗口的大小,请找到所有滑动窗口里的最大值。例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别是{4,4,6,6,6,5},如图所示:

 1 #include<iostream>
 2 #include<vector>
 3 #include<deque>
 4 using namespace std;
 5
 6 vector<int> maxInWindows(const vector<int>& num,unsigned int size)
 7 {
 8  vector<int> MaxInWindows;
 9  if(num.size()>size&&size>=1)
10  {
11   deque<int> index;
12   for(unsigned int i=0;i<size;++i)
13   {
14    while(!index.empty()&&num[i]>=num[index.back()])
15      index.pop_back();
16    index.push_back(i);
17    }
18   for(i=size;i<num.size();++i)
19   {
20     MaxInWindows.push_back(num[index.front()]);
21     while(!index.empty()&&num[i]>=num[index.back()])
22     index.pop_back();
23     if(!index.empty()&&index.front()<(int)(i-size))
24         index.pop_front();
25     index.push_back(i);
26   }
27  MaxInWindows.push_back(num[index.front()]);
28  }
29 return MaxInWindows;
30 }
31
32 void print(vector<int> result)
33 {
34     vector<int>::iterator ite;
35     for(ite=result.begin();ite!=result.end();++ite)
36         cout<<*ite<<" ";
37         cout<<endl;
38          result.clear();
39 }
40
41 void main()
42 {
43     int ia[10]={1,2,3,4,5,6,7,8,9,10};
44     vector<int> ib(ia,ia+10);
45     print(maxInWindows(ib,3));
46 }

方法2:

 1 #include<iostream>
 2 #include<vector>
 3 #include<deque>
 4 using namespace std;
 5
 6
 7 int searchmax(const vector<int>&num,unsigned int size)
 8 {
 9      int max=num[0];
10     for(int i=1;i<size;i++)
11     {
12         if(num[i]>max)
13             max=num[i];
14     }
15     return max;
16 }
17
18 vector<int> maxInWindows(vector<int>& num,unsigned int size)
19 {
20  vector<int> MaxInWindows;
21  int length=num.size();
22  for(int i=0;i<length-size+1;i++)
23  {
24   MaxInWindows.push_back(searchmax(num,size));
25       num.erase(num.begin());
26  }
27 return MaxInWindows;
28 }
29
30
31
32
33 void print(vector<int> result)
34 {
35     vector<int>::iterator ite;
36     for(ite=result.begin();ite!=result.end();++ite)
37         cout<<*ite<<" ";
38         cout<<endl;
39          result.clear();
40 }
41
42 void main()
43 {
44     int ia[10]={1,2,3,4,5,6,7,8,9,10};
45     vector<int> ib(ia,ia+10);
46     print(maxInWindows(ib,3));
47     print(ib);
48 }
时间: 2024-10-06 00:12:14

滑动窗口的最大值的相关文章

滑动窗口的最大值(STL的应用+剑指offer)

滑动窗口的最大值 参与人数:767时间限制:1秒空间限制:32768K 通过比例:21.61% 最佳记录:0 ms|8552K(来自 ) 题目描述 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}: 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1

滑动窗口的最大值-剑指Offer

滑动窗口的最大值 题目描述 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}: 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2,5

《剑指offer》:[65]滑动窗口的最大值

题目:给定一个数组和滑动窗口的大小,请找出所有滑动窗口里的最大值. 例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,它们的最大值分别为{4,4,6,6,6,5}. 滑动窗口这个概念在写过网络编程的人都应该是不陌生,主要是用来进行流控的.利用接收方剩下的缓冲数据区的大小来控制发送端的发送速度,避免发送端发送过快,导致网络拥塞及其他故障问题. 方案一:蛮力法,顺序分块扫描.例如在上例中,我们进行不断的分组和查找,3个一组,这样最终会找出其最大值.但是

【剑指offer】滑动窗口的最大值,C++实现

原创博文,转载请注明出处! # 题目 # 思路 利用C++中的双端队列保存有可能是滑动窗口最大值的下标,其中队首元素保存当前窗口最大值的下标.当滑动窗口改变时,更新队列.队列更新的规则:(1)新元素依次与队尾元素比较,如果队尾元素小于新元素,则删除队尾元素,直至队列中没有小于新元素的值.(2)更新队首元素,如果队首元素不在新滑动窗口中,则删除队首元素.(3)把每次滑动的数字的下标压入队列 找出数组中大小为3的滑动窗口的最大值,在队列中的下标一列,小括号前面的数字表示数字在数组中的下标. # 代码

《剑指offer》第五十九题(滑动窗口的最大值)

// 面试题59(一):滑动窗口的最大值 // 题目:给定一个数组和滑动窗口的大小,请找出所有滑动窗口里的最大值.例如, // 如果输入数组{2, 3, 4, 2, 6, 2, 5, 1}及滑动窗口的大小3,那么一共存在6个 // 滑动窗口,它们的最大值分别为{4, 4, 6, 6, 6, 5}, #include <iostream> #include <vector> #include <deque> using namespace std; vector<i

滑动窗口的最大值问题

给出一个序列,要求找出滑动窗口中的最大值,比如: # 序列: 2, 6, 1, 5, 3, 9, 7, 4 # 窗口大小: 4 [2, 6, 1, 5], 3, 9, 7, 4 => 6 2, [6, 1, 5, 3], 9, 7, 4 => 6 2, 6, [1, 5, 3, 9], 7, 4 => 9 2, 6, 1, [5, 3, 9, 7], 4 => 9 2, 6, 1, 5, [3, 9, 7, 4] => 9 # 期望结果: [6, 6, 9, 9, 9] 并要

剑指offer64:滑动窗口的最大值

1 题目描述 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}: 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2,5],1}, {

剑指offer:滑动窗口的最大值(栈和队列)

1. 题目描述 /* 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值. 例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}: 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2,5],

【剑指offer】滑动窗口的最大值

题目链接:滑动窗口的最大值 题意:给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}: 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,

剑指Offer(栈和队列)-滑动窗口的最大值

(滑动窗口的最大值)题目描述: 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}: 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2