社区讨论

求调线段树36pts

P2880[USACO07JAN] Balanced Lineup G参与者 4已保存回复 6

讨论操作

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

当前回复
6 条
当前快照
1 份
快照标识符
@mdxrpktc
此快照首次捕获于
2025/08/05 07:55
7 个月前
此快照最后确认于
2025/08/05 12:28
7 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,q,h[50001],a,b,tree[500001],mx[50001],mn[50001];
void update(ll x){
	mx[x]=max(mx[x*2],mx[x*2+1]);
	mn[x]=min(mn[x*2],mn[x*2+1]);
}
void buildtree(ll x,ll l,ll r){
	if (l==r){
		mn[x]=mx[x]=h[l];
		return;
	}
	ll mid=(l+r)/2;
	buildtree(2*x,l,mid);
	buildtree(2*x+1,mid+1,r);
	update(x);
}
ll querymx(ll x,ll l,ll r,ll L,ll R){
	if (L<=l && r<=R) return mx[x];
	ll mid=(l+r)/2,ans=-1;
	if (L<=mid) ans=max(ans,querymx(x*2,l,mid,L,R));
	if (mid<R) ans=max(ans,querymx(x*2+1,mid+1,r,L,R));
	return ans;
}
ll querymn(ll x,ll l,ll r,ll L,ll R){
	if (L<=l && r<=R) return mn[x];
	ll mid=(l+r)/2,ans=1e8;
	if (L<=mid) ans=min(ans,querymn(x*2,l,mid,L,R));
	if (mid<R) ans=min(ans,querymn(x*2+1,mid+1,r,L,R));
	return ans;
}
int main(){
	cin>>n>>q;
	for (ll i=1;i<=n;i++) cin>>h[i];
	buildtree(1,1,n);
	while (q--){
		cin>>a>>b;
		cout<<querymx(1,1,n,a,b)-querymn(1,1,n,a,b)<<'\n';
	}
}

回复

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

正在加载回复...