C++滑动门问题(附两种方法)

题目如下:

滑动窗口 - 题目 - Liuser's OJ

------引用自OJ网站

方法如下:

1.常规思想

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n,k;
	int a[110];
	cin>>n>>k;
	for(int i=0;i<n;i++)
	{
		cin>>a[i];
	}
	for(int i=0;i<n-k;i++)
	{
		int ma=-1;
		for(int j=i;j<i+k;j++)
		{
			ma=max(ma,a[j]);
		}
		cout<<ma<<endl;
	}
	
	
	
	return 0;
}

做起来很简单,缺点也很明显

时间复杂度太高

遇到极端数据就会出错

2.栈思想

cpp 复制代码
#include<bits/stdc++.h>
#include<stack>
using namespace std;
int a[110];
int ma[110];
int n,k;
int l=0;
int main()
{
	stack<int> s;
	stack<int> ss;
	cin>>n>>k;
	for(int i=0;i<n;i++)
	{
		cin>>a[i];
	}
	for(int i=0;i<k;i++)
	{
		if(s.empty()==true||s.top()<=a[i])
		{
			s.push(a[i]);
		}
		else if(s.top()>a[i])
		{
			int t=0;
			while(!(s.empty()==true||s.top()<=a[i]))
			{
				ss.push(s.top());
				s.pop();
				t++;
			}
			s.push(a[i]);
			for(int j=0;j<t;j++)
			{
				s.push(ss.top());
				ss.pop();
			}
		}
	}
	ma[++l]=s.top();
	while(s.empty()!=true)
	{
		ss.push(s.top());
		s.pop();
	}
	cout<<ss.top()<<" ";
	while(ss.empty()!=true)
	{
		s.push(ss.top());
		ss.pop();
	}
	for(int i=k;i<n;i++)
	{
		while(true)
		{
			if(a[i-k]==s.top())
			{
				s.pop();
				break;
			}
			ss.push(s.top());
			s.pop();
		}
		if(s.empty()==true)
		{
			s.push(ss.top());
			ss.pop();
		}
		if(a[i]<s.top())
		{
			while(true)
			{
				if(s.empty()==true)
				{
					s.push(a[i]);
					break;
				}
				if(a[i]<s.top())
				{
					ss.push(s.top());
					s.pop();
				}
				else
				{
					s.push(a[i]);
					break;
				}
			}
		}
		else if(a[i]>=s.top())
		{
			if(ss.empty()==true)
			{
				s.push(a[i]);
			}
			else
			{
				while(true)
				{
					if(ss.empty()==true)
					{
						s.push(a[i]);
						break;
					}
					if(ss.top()<=a[i])
					{
						s.push(ss.top());
						ss.pop();
					}
					else
					{
						s.push(a[i]);
						break;
					}
				}
			}
		}
		while(ss.empty()!=true)
		{
			s.push(ss.top());
			ss.pop();
		}
		ma[++l]=s.top();
		while(s.empty()!=true)
		{
			ss.push(s.top());
			s.pop();
		}
		cout<<ss.top()<<" ";
		while(ss.empty()!=true)
		{
			s.push(ss.top());
			ss.pop();
		}
	}
	cout<<endl;
	for(int i=1;i<=l;i++)
	{
		cout<<ma[i]<<" ";
	}
	
	
	return 0;
}

虽然写起来有亿点点麻烦,但是胜在稳定

!!!注意 !!!

作者写代码的时候没有注意数据范围,在网站里测试的时候会出错

自己在网站里测试的时候记得根据实际情况调整数据范围!!!!

相关推荐
勤奋的知更鸟3 分钟前
Matplotlib 绘图库使用技巧介绍
开发语言·python·matplotlib
上位机付工1 小时前
C#上位机通过WebApi访问WinCC
开发语言·c#·上位机·webapi·wincc
微信公众号:AI创造财富6 小时前
conda create -n modelscope python=3.8 conda: command not found
开发语言·python·conda
鱼会上树cy6 小时前
空间解析几何10:三维圆弧拟合【附MATLAB代码】
开发语言·matlab
IT艺术家-rookie6 小时前
golang--channel的关键特性和行为
开发语言·后端·golang
我最厉害。,。8 小时前
C2远控篇&C&C++&ShellCode分离&File提取&Http协议&Argv参数&Sock管道
c语言·c++·http
Cyrus_柯8 小时前
C++(面向对象编程——关键字)
开发语言·c++·算法·面向对象
大龄Python青年8 小时前
C语言 函数怎样通过数组来返回多个值
c语言·开发语言
LQYYDSY8 小时前
【C语言极简自学笔记】重讲运算符
c语言·开发语言·笔记
2013编程爱好者8 小时前
C++二分查找
开发语言·c++·算法·二分查找