【模板】线段树2

P3373 【模板】线段树 2
先贴个板子

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N=100050;
int n,m,mod,a[N],opr,x,y,k;
inline int read(){
	int cnt=0,f=1;char c=getchar();
	while(!isdigit(c)){if(c=='-')f=-f;c=getchar();}
	while(isdigit(c)){cnt=(cnt<<3)+(cnt<<1)+(c^48);c=getchar();}
	return cnt*f;
}
struct SEG{
	int sum,mul,add,l,r;
	#define sum(p) tr[p].sum
	#define l(p) tr[p].l
	#define r(p) tr[p].r
	#define mul(p) tr[p].mul
	#define add(p) tr[p].add
}tr[N<<2];
int Add(int a, int b){return a + b >= mod ? a + b - mod : a + b;}
int Mul(int a, int b){ return 1ll * a * b % mod; }
void pushup(int p){ sum(p)=Add(sum(p<<1), sum(p<<1|1));}
void build(int p,int l,int r){
	l(p)=l,r(p)=r;add(p)=0;mul(p)=1;
	if(l(p)==r(p)){sum(p)=a[l];mul(p)=1;return;}
	int mid=(l+r)>>1;
	build(p<<1,l,mid);build(p<<1|1,mid+1,r);
	pushup(p);
} 
void pushadd(int p, int v){
	sum(p) = Add(sum(p), Mul(r(p)-l(p)+1, v));
	add(p) = Add(add(p), v);
}
void pushmul(int p, int v){
	sum(p) = Mul(sum(p), v);
	add(p) = Mul(add(p), v);
	mul(p) = Mul(mul(p), v);
}
void pushdown(int p){
	if(mul(p)^1) pushmul(p<<1, mul(p)), pushmul(p<<1|1, mul(p)), mul(p) = 1; 
	if(add(p)) pushadd(p<<1, add(p)), pushadd(p<<1|1, add(p)), add(p) = 0;
}
void modify_add(int p,int l,int r,int d){
	if(l(p)>=l&&r(p)<=r){ pushadd(p, d); return; }
	pushdown(p);
	int mid=(l(p)+r(p))>>1;
	if(l<=mid)modify_add(p<<1,l,r,d);
	if(r>mid)modify_add(p<<1|1,l,r,d);
	pushup(p);
}
void modify_mult(int p,int l,int r,int d){
	if(l(p)>=l&&r(p)<=r){ pushmul(p, d); return; }
	pushdown(p);
	int mid=(l(p)+r(p))>>1;
	if(l<=mid)modify_mult(p<<1,l,r,d);
	if(r>mid)modify_mult(p<<1|1,l,r,d);
	pushup(p);
}
int query(int p,int l,int r){
	int ans=0;
	if(l(p)>=l&&r(p)<=r) return sum(p);
	pushdown(p);
	int mid=(l(p)+r(p))>>1;
	if(l<=mid)ans=Add(ans, query(p<<1,l,r));
	if(r>mid)ans=Add(ans, query(p<<1|1,l,r));
	return ans;
}
void debug(int p) {
	printf("%lld %lld %lld\n", sum(p), mul(p), add(p));
	if (l(p) == r(p)) return;
	debug(p << 1), debug(p << 1 | 1);
}
signed main(){
//	freopen("1.in","r",stdin);
	n=read(),m=read(),mod=read();
	for(int i=1;i<=n;i++)a[i]=read();
	build(1,1,n);
	for(int i=1;i<=m;i++){
		opr=read();
		if(opr==1){x=read(),y=read(),k=read();modify_mult(1,x,y,k);}
		if(opr==2){x=read(),y=read(),k=read();modify_add(1,x,y,k);}
		if(opr==3){x=read(),y=read();printf("%lld\n",query(1,x,y) % mod);}
//		debug(1);
//		cerr<<"---------"<<endl;
//		for(int j = 1; j <= n; j++) cout << query(1, j, j) << " " ;
//		cout << endl;
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
项目:使用AngularJs编写的简单 益智游戏(附源代码)  这是一个简单的 javascript 项目。这是一个拼图游戏,也包含一个填字游戏。这个游戏玩起来很棒。有两个不同的版本可以玩这个游戏。你也可以玩填字游戏。 关于游戏 这款游戏的玩法很简单。如上所述,它包含拼图和填字游戏。您可以通过移动图像来玩滑动拼图。您还可以选择要在滑动面板中拥有的列数和网格数。 另一个是填字游戏。在这里你只需要找到浏览器左侧提到的那些单词。 要运行此游戏,您需要在系统上安装浏览器。下载并在代码编辑器中打开此项目。然后有一个 index.html 文件可供您修改。在命令提示符中运行该文件,或者您可以直接运行索引文件。使用 Google Chrome 或 FireFox 可获得更好的用户体验。此外,这是一款多人游戏,双方玩家都是人类。 这个游戏包含很多 JavaScript 验证。这个游戏很有趣,如果你能用一点 CSS 修改它,那就更好了。 总的来说,这个项目使用了很多 javascript 和 javascript 库。如果你可以添加一些具有不同颜色选项的级别,那么你一定可以利用其库来提高你的 javascript 技能。 演示: 该项目为国外大神项目,可以作为毕业设计的项目,也可以作为大作业项目,不用担心代码重复,设计重复等,如果需要对项目进行修改,需要具备一定基础知识。 注意:如果装有360等杀毒软件,可能会出现误报的情况,源码本身并无病毒,使用源码时可以关闭360,或者添加信任。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值