/ Randle /

记录详情

Wrong Answer


  
# 状态 耗时 内存占用
#1 Wrong Answer 成绩取消 0ms 0 Bytes

代码

#include<bits/stdc++.h>
#define LL long long
const LL maxn=1e5;
inline const void read(LL &a)
{
	a=0;
	char c=getchar();
	while(c<'0'||c>'9')c=getchar();
	while(c>='0'&&c<='9')
	{
		a=(a<<1)+(a<<3)+c-'0';
		c=getchar();
	}
}
inline const void write(LL a)
{
	if(a>9)write(a/10);
	putchar(a%10+'0');
}
inline const LL max(LL a,LL b)
{
	if(a>b)return a;
	return b;
}
LL n,m;
LL height[maxn<<2],lh[maxn<<2],rh[maxn<<2],lloc[maxn<<2],rloc[maxn<<2];
inline const void update(LL p)
{
	height[p]=max(height[p<<1],height[p<<1|1]);
}
inline const void build(LL p,LL l,LL r)
{
	if(l==r){read(height[p]);return ;}
	LL mid=(l+r)>>1;
	build(p<<1,l,mid);
	build(p<<1|1,mid+1,r);
	update(p);
}
inline const void push_col(LL p,LL l,LL r)
{
	if(lh[p]||rh[p])
	{
		LL mid=(l+r)>>1;
		push_col(p<<1,l,mid);push_col(p<<1|1,mid+1,r);
		lh[p<<1]=lh[p<<1|1]=lh[p];rh[p<<1]=rh[p<<1|1]=rh[p];
		lloc[p<<1]=lloc[p<<1|1]=lloc[p];rloc[p<<1]=rloc[p<<1|1]=rloc[p];
		if(lh[p]==rh[p])height[p<<1]=height[p<<1|1]=height[p];
		else
		{
			double k=double(rh[p]-lh[p])/double(rloc[p]-lloc[p]),b=double(rh[p])-k*double(rloc[p]);
			LL minus=(LL)(max(double(l)*k+b,double(r)*k/+b));
			height[p<<1]=height[p]-minus+(LL)(max(double(l)*k+b,double(mid)*k/+b));
			height[p<<1|1]=height[p]-minus+(LL)(max(double(mid+1)*k+b,double(r)*k+b));
		}
		lh[p]=rh[p]=lloc[p]=rloc[p]=0;	
	}
}
inline const LL query(LL p,LL l,LL r,LL ll,LL rr)
{
	if(l>=ll&&r<=rr)return height[p];
	push_col(p,l,r);
	LL mid=(l+r)>>1,ans=0;
	if(mid>=ll)ans=max(ans,query(p<<1,l,mid,ll,rr));
	if(mid+1<=rr)ans=max(ans,query(p<<1|1,mid+1,r,ll,rr));
	return ans;
}
inline const void modify(LL p,LL l,LL r,LL ll,LL rr,LL lup,LL rup)
{
	push_col(p,l,r);
	if(l>=ll&&r<=rr)
	{
		push_col(p,l,r);
		lloc[p]=ll;rloc[p]=rr;lh[p]=lup;rh[p]=rup;
		if(lh[p]==rh[p])height[p]=height[p]+rh[p];
		else 
		{
			double k=double(rh[p]-lh[p])/double(rloc[p]-lloc[p]),b=double(rh[p])-k*double(rloc[p]);
			height[p]=height[p]+(LL)(max(double(l)*k+b,double(r)*k/+b));
		}
		return ;
	}
	LL mid=(l+r)>>1;
	if(mid>=ll)modify(p<<1,l,mid,ll,rr,lup,rup);
	if(mid+1<=rr)modify(p<<1|1,mid+1,r,ll,rr,lup,rup);
	update(p);
}
int main()
{
	read(n);
	build(1,1,n);
	read(m);
	long long t,x,y,z,left;
	while(m)
	{
		read(t);
		if(t==1)
		{
			read(x);read(y);read(left);
			modify(1,1,n,left,left+x-1,y,y);
		}
		if(t==2)
		{
			read(x);read(y);read(left);
			modify(1,1,n,left,left+(y>>1),0,y);
			modify(1,1,n,left+(x>>1),left+(x>>1),-y,-y);
			modify(1,1,n,left+(x>>1),left+x-1,y,0);
		}
		if(t==3)
		{
			read(x);read(y);read(z);read(left);
			modify();
			modify();
		}
		if(t==4)
		{
			read(x);read(y);
			write(query(1,1,n,x,y));printf("\n");
		}
		m--;
	}
	return 0;
}

信息

递交者
类型
递交
题目
图形堆积(原创)
题目数据
下载
语言
C++
递交时间
2017-10-07 19:57:39
评测时间
2017-10-07 19:57:47
评测机
分数
0
总耗时
0ms
峰值内存
0 Bytes