我是靠谱客的博主 仁爱板栗,最近开发中收集的这篇文章主要介绍BZOJ 4370: [IOI2015]horses马 线段树+贪心+对数,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

显然如果卖出的话肯定要在同一天卖出.  

那么我们只需维护 $max(y_{i}prod x_{i})$ 即可.  

乘法维护不了,取一个对数就好了. 

code:

#include <cstdio>
#include <cmath>
#include <cstring>
#include <algorithm>
#define N 500003
#define ll long long
#define mod 1000000007
#define lson now<<1
#define rson now<<1|1
#define setIO(s) freopen(s".in","r",stdin)
using namespace std;
double a[N],b[N];
int X[N],Y[N],n;
struct node
{
int id,sum2;
double maxv,sum;
}s[N<<2];
void pushup(int now)
{
s[now].sum=s[lson].sum+s[rson].sum;
s[now].sum2=(ll)s[lson].sum2*s[rson].sum2%mod;
if(s[lson].maxv>s[rson].maxv+s[lson].sum)
{
s[now].maxv=s[lson].maxv;
s[now].id=s[lson].id;
}
else
{
s[now].maxv=s[lson].sum+s[rson].maxv;
s[now].id=(ll)s[lson].sum2*s[rson].id%mod;
}
}
void build(int l,int r,int now)
{
if(l==r)
{
s[now].maxv=a[l]+b[l];
s[now].sum=a[l];
s[now].sum2=X[l]%mod;
s[now].id=(ll)X[l]*Y[l]%mod;
return;
}
int mid=(l+r)>>1;
build(l,mid,lson),build(mid+1,r,rson),pushup(now);
}
void update_x(int l,int r,int now,int p,int v)
{
if(l==r)
{
X[p]=v;
a[p]=log2(v);
s[now].maxv=a[l]+b[l];
s[now].sum=a[l];
s[now].sum2=X[l]%mod;
s[now].id=(ll)X[l]*Y[l]%mod;
return;
}
int mid=(l+r)>>1;
if(p<=mid) update_x(l,mid,lson,p,v);
else update_x(mid+1,r,rson,p,v);
pushup(now);
}
void update_y(int l,int r,int now,int p,int v)
{
if(l==r)
{
Y[p]=v;
b[p]=log2(v);
s[now].maxv=a[l]+b[l];
s[now].sum=a[l];
s[now].id=(ll)X[l]*Y[l]%mod;
return;
}
int mid=(l+r)>>1;
if(p<=mid) update_y(l,mid,lson,p,v);
else update_y(mid+1,r,rson,p,v);
pushup(now);
}
int main()
{
// setIO("input");
int i,j,m;
scanf("%d",&n);
for(i=1;i<=n;++i) scanf("%d",&X[i]),a[i]=log2(X[i]);
for(i=1;i<=n;++i) scanf("%d",&Y[i]),b[i]=log2(Y[i]);
build(1,n,1);
scanf("%d",&m);
printf("%dn",s[1].id);
while(m--)
{
int w,e,r;
scanf("%d%d%d",&w,&e,&r),++e;
if(w==1)
{
update_x(1,n,1,e,r);
}
else
{
update_y(1,n,1,e,r);
}
printf("%dn",s[1].id);
}
return 0;
}

  

最后

以上就是仁爱板栗为你收集整理的BZOJ 4370: [IOI2015]horses马 线段树+贪心+对数的全部内容,希望文章能够帮你解决BZOJ 4370: [IOI2015]horses马 线段树+贪心+对数所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部