线段树暴力

#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=(a);i<=(b);i++)
#define per(i,a,b) for(int i=(a);i>=(b);i--)
#define ll long long
using namespace std;
const ll inf=1e8;
const int N=2e5;
struct Q{int op,l,r;}q[N];
int num[4],tag[N],n,m,op,l,r;
ll a[N],sum[N];
double sumv[N*20],maxn[N*20],minv[N*20];
bool flag[N*20];
ll read(){
	ll num=0;char ch=getchar();
	while(!isdigit(ch))ch=getchar();
	while(isdigit(ch))num=num*10+ch-'0',ch=getchar();
	return num;
}
void Print(ll x){if(x>9)Print(x/10);putchar(x%10+'0');}
double work(ll a,int b){
	if(b==0)return min(a,inf);
	if(b<0){
		double c=a;
		while(a&&b<0){
			c=sqrt(c),b++;
		}
		return min(c,1.0*inf);
	}
	if(a>=inf)return inf;
	while(b){
		a=a*a,b--;
		if(a>=inf)return inf;
	}return a;
}
void subtask1(){
	rep(i,1,m){
		op=q[i].op,l=q[i].l,r=q[i].r;
		if(op==1) rep(i,l,r)tag[i]++;
		if(op==2) rep(i,l,r)tag[i]--;
		if(op==3){
			double ans=0;
			rep(i,l,r)ans+=work(a[i],tag[i]);
			Print(round(ans)),puts("");
		}
	}
}
void subtask2(){
	rep(i,1,n)a[i]=min(a[i],inf);
	rep(i,1,n)sum[i]=sum[i-1]+a[i];
	rep(i,1,m){
		op=q[i].op,l=q[i].l,r=q[i].r;
		Print(sum[r]-sum[l-1]),puts("");
	}
}
void build3(int o,int L,int R){
	int lc=o<<1,rc=o<<1|1,M=L+R>>1;
	if(L==R){
		maxn[o]=a[L];
		sumv[o]=min(a[L],inf);
		return;
	}
	build3(lc,L,M),build3(rc,M+1,R);
	sumv[o]=sumv[lc]+sumv[rc];
	maxn[o]=max(maxn[lc],maxn[rc]);
}
void update3(int o,int L,int R,int ql,int qr){
	int lc=o<<1,rc=o<<1|1,M=L+R>>1;
	if(flag[o])return;
	if(L==R){
		sumv[o]=sqrt(sumv[o]);
		if(sumv[o]<=1)flag[o]=1;
		return;
	}
	if(ql<=M)update3(lc,L,M,ql,qr);
	if(M<qr)update3(rc,M+1,R,ql,qr);
	sumv[o]=sumv[lc]+sumv[rc];
	flag[o]=flag[lc]&&flag[rc];
}
double query3(int o,int L,int R,int ql,int qr){
	int lc=o<<1,rc=o<<1|1,M=L+R>>1;
	double ans=0;
	
	if(ql<=L&&R<=qr){
		return sumv[o];
	}
	if(ql<=M) ans+=query3(lc,L,M,ql,qr);
	if(M<qr) ans+=query3(rc,M+1,R,ql,qr);
	return ans;
}
void subtask3(){
	build3(1,1,n);
	rep(i,1,m){
		op=q[i].op,l=q[i].l,r=q[i].r;
		if(op==2){
			update3(1,1,n,l,r);
		}else{
		
			Print(round(query3(1,1,n,l,r))),puts("");
		}
	}
}
void build4(int o,int L,int R){
	int lc=o<<1,rc=o<<1|1,M=L+R>>1;
	if(L==R){
		//cout<<L<<" "<<a[L]<<"\n";
		
		sumv[o]=a[L];
		if(a[L]==1)flag[o]=1;
		minv[o]=a[L];
		return;
	}
	build4(lc,L,M),build4(rc,M+1,R);
	sumv[o]=sumv[lc]+sumv[rc];
	minv[o]=min(minv[lc],minv[rc]);
	flag[o]=flag[lc]&&flag[rc];
}
void update4(int o,int L,int R,int ql,int qr){
	int lc=o<<1,rc=o<<1|1,M=L+R>>1;
	if(flag[o])return;
	if(L==R){
		sumv[o]=sumv[o]*sumv[o];
		//if(sumv[o]>=inf)flag[o]=1;
	//	cout<<sumv[o]<<" "<<L<<"\n";
		//minv[o]=sumv[o];
		if(sumv[o]>inf)flag[o]=1;
		sumv[o]=min(sumv[o],1.0*inf);
		
		return;
	}
	if(ql<=M)update4(lc,L,M,ql,qr);
	if(M<qr)update4(rc,M+1,R,ql,qr);
	sumv[o]=sumv[lc]+sumv[rc];
	minv[o]=min(minv[lc],minv[rc]);
	flag[o]=flag[lc]&&flag[rc];
}
ll query4(int o,int L,int R,int ql,int qr){
	int lc=o<<1,rc=o<<1|1,M=L+R>>1;
	ll ans=0;
	
	if(ql<=L&&R<=qr) return sumv[o];
	
	if(ql<=M) ans+=query4(lc,L,M,ql,qr);
	if(M<qr) ans+=query4(rc,M+1,R,ql,qr);
	return ans;
}
void subtask4(){
	build4(1,1,n);
	rep(i,1,m){
		op=q[i].op,l=q[i].l,r=q[i].r;
		if(op==1){
			update4(1,1,n,l,r);
		}else{
		
			Print(query4(1,1,n,l,r)),puts("");
		}
	}
}
double fuck[N];
double cal(int i,int tmp){
	//if(b>20&&a!=0)return inf;
	
	return fuck[i]*pow(2.0,tmp*1.0)>8? 100000000:pow(a[i],pow(2.0,tmp*1.0));
}
void subtask5(){
	//cout<<1;
	rep(i,1,n)fuck[i]=log10(a[i]);
	rep(i,1,m){
		op=q[i].op,l=q[i].l,r=q[i].r;
		if(op==1) tag[l]++,tag[r+1]--;
		if(op==2) tag[l]--,tag[r+1]++;
		if(op==3){
			long double ans=0;
			ll tmp=0;
			rep(i,1,l-1)tmp+=tag[i];
			//rep(i,1,n)tmp[i]=tag[i]+tmp[i-1];
			rep(i,l,r){
				tmp+=tag[i];
				ans+=cal(i,tmp);
			}
			Print(round(ans)),puts("");
		}
	}
}
int main()
{
	freopen("forever.in","r",stdin);
	freopen("forever.out","w",stdout);
	n=read(),m=read();
	rep(i,1,n)a[i]=read();
	rep(i,1,m)scanf("%d%d%d",&q[i].op,&q[i].l,&q[i].r),num[q[i].op]++;
	if(n<=10000)subtask1();
	else if(num[1]==0&&num[2]==0&&num[3])subtask2();
	else if(num[3]==0&&num[1]&&num[2])return 0;
	else if(num[1]==0&&num[2]&&num[3])subtask3();
	else if(num[2]==0&&num[1]&&num[3])subtask4();
	else if(num[3]<=500) subtask5();
	return 0;
}  
  • 最长的暴力,写了一下午
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值