80MLE,救救孩子,如何用滚动数组优化

P1440 求m区间内的最小值

plm123 @ 2019-11-12 18:32:09


#include <bits/stdc++.h>
using namespace std;
int n,m,Ma[2000010][21];
int cST(int l,int r){
    int k=log2(r-l+1);
    return min(Ma[l][k],Ma[r-(1<<k)+1][k]);
}//查询
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++){
    scanf("%d",&Ma[i][0]);  
    }
    for(int j=1;j<=21;j++)
        for(int i=1;i+(1<<j)-1<=n;i++)
            Ma[i][j]=min(Ma[i][j-1],Ma[i+(1<<(j-1))][j-1]);//建表
    printf("%d\n",0);//特别判断
    for(int i=-m+2;i+m-1<n;i++){
    if(i<=0)printf("%d\n",cST(1,i+m-1));
    else printf("%d\n",cST(i,i+m-1));   
    }
    return 0;
}

by plm123 @ 2019-11-12 18:32:44

求助巨佬


by fxhfxh55555 @ 2019-11-12 18:49:05

ST表过不去吧。。。这空间卡死了。。。而且ST表你怎么搞滚动数组。。。


by a17436223 @ 2019-11-16 22:21:56

这题第二维没必要,直接删就行,不过要特判下i小于m的情况


|