P3373 模板 線段樹 2

2021-09-27 07:49:25 字數 2599 閱讀 9759

題目描述

如題,已知乙個數列,你需要進行下面三種操作:

1.將某區間每乙個數乘上x

2.將某區間每乙個數加上x

3.求出某區間每乙個數的和

輸入格式

第一行包含三個整數n、m、p,分別表示該數列數字的個數、操作的總個數和模數。

第二行包含n個用空格分隔的整數,其中第i個數字表示數列第i項的初始值。

接下來m行每行包含3或4個整數,表示乙個操作,具體如下:

操作1: 格式:1 x y k 含義:將區間[x,y]內每個數乘上k

操作2: 格式:2 x y k 含義:將區間[x,y]內每個數加上k

操作3: 格式:3 x y 含義:輸出區間[x,y]內每個數的和對p取模所得的結果

輸出格式

輸出包含若干行整數,即為所有操作3的結果。

輸入輸出樣例

輸入 #1 複製

5 5 38

1 5 4 2 3

2 1 4 1

3 2 5

1 2 4 2

2 3 5 5

3 1 4

輸出 #1 複製

17

2

說明/提示

時空限制:1000ms,128m

資料規模:

對於30%的資料:n<=8,m<=10

對於70%的資料:n<=1000,m<=10000

對於100%的資料:n<=100000,m<=100000

(資料已經過加強_)

ac_code:

#include

#define lson rt<<1,l,mid

#define rson rt<<1|1,mid+1,r

typedef

long

long ll;

using namespace std;

const ll maxn =

1e5+5;

ll n,m,mod;

ll sum[maxn<<2]

;ll tag1[maxn<<2]

,tag2[maxn<<2]

;ll a[maxn];/*

sum: 存區間和

a:存原始資料

tag1: 乘v lazy tag

tag2: 加v lazy tag

*/inline bool read

(ll &x)

inline

void

write

(ll x)

inline

void

push_up

(ll rt)

void

build

(ll rt,ll l,ll r)

ll mid =

(l + r)

>>1;

build

(lson)

;build

(rson)

;push_up

(rt);}

inline

void

push_down

(ll rt,ll l,ll r)

if(tag2[rt]

>0)

}//操作區間【l,r】

void

update_range

(ll l,ll r,ll v,ll op,ll rt,ll l,ll r)

else

return;}

push_down

(rt,l,r)

;//標記下傳

ll mid =

(l + r)

>>1;

if(l <= mid)

update_range

(l,r,v,op,lson);if

(r > mid)

update_range

(l,r,v,op,rson)

;push_up

(rt)

;//向上更新資訊

}ll query

(ll l,ll r,ll rt,ll l,ll r)

push_down

(rt,l,r)

;//標記下傳更新可能要涉及到的區間

ll mid =

(l + r)

>>1;

ll res =0;

if(l <= mid)

//左孩子涉及

res =

(res+

query

(l,r,lson)

)%mod;

if(r > mid)

//右孩子涉及

res =

(res+

query

(l,r,rson)

)%mod;

return res%mod;}/*

取模過程中,也不能一味的取模,

有些不必要的就可以不取模,否則tle!!!

*/int

main()

build(1

,1,n);

while

(m--

)else

}return0;

}

P3373 模板 線段樹2

如題,已知乙個數列,你需要進行下面三種操作 1.將某區間每乙個數乘上x 2.將某區間每乙個數加上x 3.求出某區間每乙個數的和 include include using namespace std const int maxn 100005 int n,m,p long long arr maxn...

P3373 模板 線段樹 2

ac 這裡的延遲標記要開兩個,分別記錄加法的值和乘法的值,但是乘法和加法的優先順序不一樣,不規定他們的順序的話會有錯誤,所以可以規定乘法優先,即規定好該結點的值等於該節點的值 父節點的乘法延遲標記的值 父節點加法延遲標記的值 區間長度,即,sum num 2 sum num 2 add num wc...

P3373 模板 線段樹 2

題目描述 如題,已知乙個數列,你需要進行下面三種操作 1.將某區間每乙個數乘上x 2.將某區間每乙個數加上x 3.求出某區間每乙個數的和 輸入格式 第一行包含三個整數n m p,分別表示該數列數字的個數 操作的總個數和模數。第二行包含n個用空格分隔的整數,其中第i個數字表示數列第i項的初始值。接下來...