社区讨论

WA 0pts 求调

P2251质量检测参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@miq13vo7
此快照首次捕获于
2025/12/03 21:14
3 个月前
此快照最后确认于
2025/12/03 21:17
3 个月前
查看原帖

WA 0pts 求调

CPP
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxN=1e5+5;
int n,m;
int dp[22][maxN],a[maxN];
void init()
{
	for(int i=1;i<=n;i++)
	{
		dp[0][i]=a[i];
	}
	for(int i=1;i<=20;i++)
	{
		for(int j=1;j<=n;j++)
		{
			if(1<<(i-1)>n) continue;
			dp[i][j]=min(dp[i-1][j],dp[i-1][j+(1<<(i-1))]);
		}
	}
}
int query(int l,int r)
{
	int tms=log2(r-l+1)+1;
	return min(dp[tms][l],dp[tms][r-(1<<tms)+1]);
}
signed main()
{
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
	}
	init();
	for(int i=1;i<=n-m+1;i++)
	{
		cout<<query(i,i+m-1)<<"\n";
	}
}

回复

0 条回复,欢迎继续交流。

正在加载回复...