日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

洛谷 P3332 [ZJOI2013]K大数查询 解题报告

發(fā)布時(shí)間:2025/4/16 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 洛谷 P3332 [ZJOI2013]K大数查询 解题报告 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

P3332 [ZJOI2013]K大數(shù)查詢(xún)

題目描述

\(N\)個(gè)位置,\(M\)個(gè)操作。操作有兩種,每次操作如果是\(\tt{1\ a\ b\ c}\)的形式表示在第\(a\)個(gè)位置到第\(b\)個(gè)位置,每個(gè)位置加入一個(gè)數(shù)\(c\)如果是\(\tt{2\ a\ b\ c}\)形式,表示詢(xún)問(wèn)從第\(a\)個(gè)位置到第\(b\)個(gè)位置,第\(C\)大的數(shù)是多少。

輸入輸出格式

輸入格式:

第一行\(N\)\(M\)接下來(lái)\(M\)行,每行形如\(\tt{1\ a\ b\ c}\)\(\tt{2\ a\ b\ c}\)

輸出格式:

輸出每個(gè)詢(xún)問(wèn)的結(jié)果

說(shuō)明

\(N,M\le 50000\)

\(a\le b\le N\)

\(1\)操作中\(abs(c)\le N\)

\(2\)操作中\(c\le long long\)


把整體二分的樹(shù)狀數(shù)組改成線(xiàn)段樹(shù)區(qū)間操作即可


Code:

#include <cstdio> #define ll long long #define rep(i,a,b) for(int i=a;i<=b;i++) const int N=1e5+10; struct node{int op,l,r;ll c;}q[N],ql[N],qr[N]; int ans[N],n,m,Q; ll sum[N<<1],tag[N<<1]; #define ls id<<1 #define rs id<<1|1 void pushdown(int id,int L,int R) {if(tag[id]){int Mid=L+R>>1;sum[ls]+=tag[id]*(Mid+1-L),sum[rs]+=tag[id]*(R-Mid);tag[ls]+=tag[id],tag[rs]+=tag[id];tag[id]=0;} } void change(int id,int L,int R,int l,int r,ll d) {if(L==l&&R==r){tag[id]+=d,sum[id]+=1ll*(R+1-L)*d;return;}pushdown(id,L,R);int Mid=L+R>>1;if(r<=Mid) change(ls,L,Mid,l,r,d);else if(l>Mid) change(rs,Mid+1,R,l,r,d);else change(ls,L,Mid,l,Mid,d),change(rs,Mid+1,R,Mid+1,r,d);sum[id]=sum[ls]+sum[rs]; } ll query(int id,int L,int R,int l,int r) {if(L==l&&R==r)return sum[id];pushdown(id,L,R);int Mid=L+R>>1;if(r<=Mid) return query(ls,L,Mid,l,r);else if(l>Mid) return query(rs,Mid+1,R,l,r);else return query(ls,L,Mid,l,Mid)+query(rs,Mid+1,R,Mid+1,r); } void divide(int l,int r,int s,int t) {if(s>t) return;if(l==r) {rep(i,s,t)ans[q[i].op]=l;return;}int mid=l+r>>1,lp=0,rp=0;rep(i,s,t){if(q[i].op){ll c=query(1,1,n,q[i].l,q[i].r);if(c>=q[i].c) qr[++rp]=q[i];else ql[++lp]=q[i],ql[lp].c-=c;}else{if(q[i].c>mid) change(1,1,n,q[i].l,q[i].r,1),qr[++rp]=q[i];else ql[++lp]=q[i];}}rep(i,s,t)if(!q[i].op&&q[i].c>mid) change(1,1,n,q[i].l,q[i].r,-1);rep(i,s,s+lp-1) q[i]=ql[i+1-s];rep(i,s+lp,t) q[i]=qr[i+1-s-lp];divide(l,mid,s,s+lp-1),divide(mid+1,r,s+lp,t); } int main() {scanf("%d%d",&n,&m);rep(i,1,m){scanf("%d%d%d%lld",&q[i].op,&q[i].l,&q[i].r,&q[i].c),--q[i].op;if(q[i].op) q[i].op=++Q;}divide(-n,n,1,m);rep(i,1,Q) printf("%d\n",ans[i]);return 0; }

2018.11.1

轉(zhuǎn)載于:https://www.cnblogs.com/butterflydew/p/9887148.html

總結(jié)

以上是生活随笔為你收集整理的洛谷 P3332 [ZJOI2013]K大数查询 解题报告的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。