为什么样例过了,全WA,用的是分块,本题裸
  • 板块P1816 忠诚
  • 楼主lmrttx
  • 当前回复3
  • 已保存回复3
  • 发布时间2020/12/27 20:02
  • 上次更新2023/11/5 05:35:22
查看原帖
为什么样例过了,全WA,用的是分块,本题裸
344382
lmrttx楼主2020/12/27 20:02

额么么么,我太菜了。

#include<bits/stdc++.h>
//我永远喜欢珂朵莉和分块! 
using namespace std;
#define maxn 1000010
#define int long long
int cnt,n,m,belong[maxn],a[maxn],Min[4500],l[maxn],r[maxn];
int ask(int x,int y){
	int now=0x7f;
    for(register int i=x;i<=min(belong[x]*cnt,y);i++)
	now=min(now,a[i]);
    if(belong[x]!=belong[y]){
		for(register int i=(belong[y]-1)*cnt+1;i<=y;i++)
        now=min(now,a[i]);
	}
    for(register int i=belong[x]+1;i<belong[y];i++)now=min(now,Min[i]);
	return now;
}
signed main(){
	scanf("%lld%lld",&n,&m);
    cnt=sqrt(n);
    memset(Min,0x7f,sizeof(Min));
	for(register int i=1;i<=n;i++){
		scanf("%lld",&a[i]);belong[i]=(i-1)/cnt+1;
        
		Min[belong[i]]=min(Min[belong[i]],a[i]);
	}
	for(register int i=1;i<=m;i++)
    scanf("%lld%lld",&l[i],&r[i]);
	for(register int i=1;i<=m;i++)
    printf("%lld ",ask(l[i],r[i]));
	return 0;
}  
2020/12/27 20:02
加载中...