MLE 与 RE

P1440 求m区间内的最小值

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提成全局变量,不在函数中定义,减小空间,数组在开小一点点。


|