Lem0nTree @ 2024-07-11 10:47:04
RT,我的代码不是MLE3个点就是RE3个点,求问数组开多大(用的dp求RMQ)
#include<bits/stdc++.h>
using namespace std;
long long n,m,a[1000005],dp[1000005][20];
long long rmq(long long l,long long r){
long long k=log2(r-l+1);
return min(dp[l][k],dp[r-(1<<k)+1][k]);
}
int main(){
// freopen("P1440_2.in","r",stdin);
std::ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>n>>m;
for(long long i=1;i<=n;i++){
cin>>a[i];
dp[i][0]=a[i];
}
for(long long j=1;j<=20&&(1<<j)<=n;j++){
for(long long i=1;i+(1<<j)-1<=n;i++){
dp[i][j]=min(dp[i][j-1],dp[i+(1<<j-1)][j-1]);
}
}
cout<<0<<endl;
for(long long i=1;i<=m;i++){
cout<<rmq(1,i)<<endl;
}
for(long long i=m+1;i<n;i++){
cout<<rmq(i-m+1,i)<<endl;;
}
return 0;
}
by yangyafan @ 2024-07-11 10:48:38
其实你可以换个解法,这个就是你的空间爆掉了
by Lem0nTree @ 2024-07-11 10:49:18
错的都是#2、#9、#10
by lucasjj @ 2024-07-11 11:12:29
会不会是函数系统栈爆了?
by lucasjj @ 2024-07-11 11:14:29
我建议你把k提成全局变量,不在函数中定义,减小空间,数组在开小一点点。