bzoj3188 [Coci 2011]Upit(分块)
Time Limit: 10 Sec Memory Limit: 128 MB
Description

你需要维护一个序列,支持以下4种操作。一,将区间(u,v)的数覆盖为C;二,
将区间(u,v)的数依次加上一个以C为首项、C为公差的等差数列;三,将数C插入
第i个位置;四,查询区间(u,v)的数的和。序列最初有n个数,一共会有Q次操
作。保证结果在longlong范围内。
Sample Input
1 2 3 4 5
1 5 5 0
4 4 5
4 5 5
2 1 5 1
4 1 5
Sample Output
0
25
HINT
n, Q <= 100,000.
我非常喜欢分块,所以我用分块过了这题
#include<iostream>
#include<cstdio>
#include<vector>
#include<cmath>
#include<algorithm>
#define ri register int
using namespace std;
typedef long long ll;
ll read(){
char c=getchar(); ll x=; bool f=;
while(c<''||c>'') f=f&&(c!='-'),c=getchar();
while(''<=c&&c<='') x=x*+c-,c=getchar();
return f?x:-x;
}
#define N 60005
int n,Q,idm,B,sm[N];
ll s[N],w[N],d[N],k[N];
bool a[N],b[N];
vector <int> h; //从左到右块的编号
vector <ll> g[N];
inline ll G(int x){return g[x].size();}
inline int id(int x){return lower_bound(sm+,sm+idm+,x)-sm-;}//x属于哪个块
void down(int x){
if(a[x]) s[x]=G(x)*w[x],g[x].assign(G(x),w[x]),a[x]=w[x]=;
if(b[x]){
ll q=d[x],q2=k[x],t=; b[x]=k[x]=d[x]=s[x]=;
for(ri i=;i<G(x);++i) t+=q,g[x][i]+=t+q2,s[x]+=g[x][i];
}
}
void cover(int x,int y,ll v){
ri ix=id(x),iy=id(y),L=h[ix],R=h[iy],l=x-sm[ix]-,r=y-sm[iy]-;
if(L==R){
down(L);
for(ri i=l;i<=r;++i) s[L]+=(v-g[L][i]),g[L][i]=v;
return ;
}down(L),down(R);
for(ri i=l;i<G(L);++i) s[L]+=(v-g[L][i]),g[L][i]=v;
for(ri j=ix+,i;j<iy;++j) i=h[j],s[i]=v*G(i),b[i]=k[i]=d[i]=,w[i]=v,a[i]=;
for(ri i=;i<=r;++i) s[R]+=(v-g[R][i]),g[R][i]=v;
}
void add(int x,int y,ll v){
ri ix=id(x),iy=id(y),L=h[ix],R=h[iy],l=x-sm[ix]-,r=y-sm[iy]-; ll q=;
if(L==R){
down(L);
for(ri i=l;i<=r;++i) q+=v,s[L]+=q,g[L][i]+=q;
return ;
}down(L),down(R);
for(ri i=l;i<G(L);++i) q+=v,s[L]+=q,g[L][i]+=q;
for(ri j=ix+,i;j<iy;++j){
i=h[j];
if(a[i]){
s[i]=G(i)*w[i];
if(b[i]) s[i]+=(d[i]+d[i]*G(i))*G(i)/+k[i]*G(i);
}
s[i]+=(v+v*G(i))*G(i)/+q*G(i);
b[i]=; d[i]+=v; k[i]+=q; q+=v*G(i);
}
for(ri i=;i<=r;++i) q+=v,s[R]+=q,g[R][i]+=q;
}
void split(int x){
ri ix=id(x),L=h[ix];
h.insert(h.begin()+ix+,idm);
for(ri i=B;i<G(L);++i)
g[idm].push_back(g[L][i]),s[idm]+=g[L][i],s[L]-=g[L][i];
g[L].erase(g[L].begin()+B,g[L].end()); idm++;
}
void ins(int x,ll v){
ri ix=id(x),L=h[ix],l=x-sm[ix]-;
down(L); g[L].insert(g[L].begin()+l,v); s[L]+=v;
if(G(L)>B*) split(x);//暴力拆块
for(ri i=;i<idm;++i) sm[i+]=sm[i]+G(h[i]);
}
ll ask(int x,int y){
ri ix=id(x),iy=id(y),L=h[ix],R=h[iy],l=x-sm[ix]-,r=y-sm[iy]-; ll re=;
if(L==R){
down(L);
for(ri i=l;i<=r;++i) re+=g[L][i];
return re;
}down(L),down(R);
for(ri i=l;i<G(L);++i) re+=g[L][i];
for(ri j=ix+;j<iy;++j) re+=s[h[j]];
for(ri i=r;i>=;--i) re+=g[R][i];
return re;
}
int main(){
n=read(),Q=read(); ll q,x,y; sm[]=-; B=sqrt(n);
for(ri i=;i<n;++i) q=read(),g[i/B].push_back(q),s[i/B]+=q;
while(idm*B<=n) sm[idm+]=sm[idm]+G(idm),h.push_back(idm++);//sm[i]:第$i-1$块的右端点
while(Q--){
q=read(),x=read(),y=read();
if(q==) cover(x-,y-,read());
if(q==) add(x-,y-,read());
if(q==) ins(x-,y);
if(q==) printf("%lld\n",ask(x-,y-));
}return ;
}
bzoj3188 [Coci 2011]Upit(分块)的更多相关文章
- BZOJ3188: [Coci 2011]Upit
3188: [Coci 2011]Upit Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 72 Solved: 24[Submit][Status] ...
- Dbzoj#3188. [Coci 2011]Upit
写道数据结构练练手哈哈哈 // It is made by XZZ #include<cstdio> #include<algorithm> #include<cstdl ...
- [SinGuLaRiTy] COCI 2011~2012 #2
[SinGuLaRiTy-1008] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 测试题目 对于所有的题目:Time Limit:1s ...
- 【BZOJ 3188】【Coci 2011】Upit Splay模板题
转啊转终于转出来了,然而我的模板跟陈竞潇学长的模板一模一样,还是太弱啊,第一次用指针. #include<cstdio> #include<cstring> #include& ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- 【vijos】1791 骑士的旅行(特殊的技巧)
https://vijos.org/p/1791 暴力的话只想到bfs,然后估计是状态超了才得20分. 噗,为啥暴力就不能想得简单点QAQ.....这种思想很好啊. 这一题我看了题解后不得不说我竟然没 ...
- TOJ4505: KOSARE
TOJ4505: KOSARE Time Limit(Common/Java):10000MS/30000MS Memory Limit:65536KByteTotal Submit: 11 ...
- 【莫队算法】【权值分块】bzoj2223 [Coci 2009]PATULJCI
不带修改主席树裸题<=>莫队+权值分块裸题. 复杂度O(m*sqrt(n)). P.S.题目描述坑爹,第二个数是权值的范围. #include<cstdio> #include ...
- 【BZOJ-2453&2120】维护队列&数颜色 分块 + 带修莫队算法
2453: 维护队列 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 653 Solved: 283[Submit][Status][Discuss] ...
随机推荐
- Python---进阶---logging---logger
一.####用logging的四大组件来实现日志的功能 - 打印出函数执行的时间,日志的等级,日志的消息 - 用装饰器 - 不同的日志,要记录不同等级的日志消息 ------------------- ...
- ubuntu 14.04 安装openjdk 8
最近准备在ubuntu14.04上安装Oracle,但是需要提前安装jdk,发现问题挺多的,后面看到了如下的操作步骤,成功安装,特意记录下来. 致谢:https://www.yangshenglian ...
- 面试题常考&必考之--js中的难点!!!原型链,原型(__proto__),原型对象(prototype)结合例子更易懂
1>首先,我们先将函数对象认识清楚: 补充snow的另一种写法: var snow =function(){}; 2>其次:就是原型对象 每当我们定义一个函数对象的时候,这个对象中就会包含 ...
- HTML5基础知识汇总(一)
一.HTML的开发工具和使用的浏览器 开发工具:记事本等文本编辑器,Atom.VisualStudioCode( VSCode).Brackets.Sublime text和Hbuider. 浏览器: ...
- css盒子模型中的border属性
认识border属性 我们可以通过boder属性来为元素设置边框:元素的边框 (border) 是围绕元素内容和内边距的一条或多条线.CSS border 属性允许你规定元素边框的样式.宽度和 ...
- Java并行
序言 Java 有四种并行方式: 1.thread 使用“原汁原味”的裸线程 2.Executor (java 5 以后出现的) 3.Forkjoin 框架 (java 8 出现的) 4.Actor ...
- 软件工程 in MSRA 黄金点游戏-第一次结对编程
简单介绍 第一次结对编程,邹欣老师选择了一个博弈游戏作为题目.博弈论是一门非常有趣的学科.之前竞赛时接触的博弈论大部分都是存在均衡点/必胜策略的.像这次这种多人参与,没有完美策略,你方唱罢我登台的游戏 ...
- Codeforce |Educational Codeforces Round 77 (Rated for Div. 2) B. Obtain Two Zeroes
B. Obtain Two Zeroes time limit per test 1 second memory limit per test 256 megabytes input standard ...
- sqlserver通过select查询出连续的日历临时表
首先我们需要用到这个 select * FROM master..spt_values n WHERE n.type = 'p' AND n.number <= 7 里面分几个列,我们需要连续的 ...
- Java 位运算超全面总结
1.原码.反码.补码 关于原码.反码.补码的相关知识作者不打算在这里长篇大论,相关知识已有别的大佬总结很好了,还请老铁自行 Google,不过有篇知乎回答是作者学编程以来见过对相关知识最通俗易懂,生动 ...