题意:询问区间有多少个连续的段,而且这段的颜色在[L,R]才算贡献,每段贡献是1。 有单点修改和区间查询。

思路:46min交了第一发树套树,T了。 稍加优化多交几次就过了。

不难想到,除了L这个点,其他的点都可以只统计这一段的段首。把位置看成x,颜色看成y,就成了二维平面就矩形内点的个数,这就是裸的树套树或者CDQ了。

树套树:34**ms。

/*
2019南昌网络赛I。
询问区间有多少个连续的段,而且这段的颜色在[L,R]才算贡献,每段贡献是1。 有单点修改和区间查询。
也可以CDQ来做,常数小很多。
*/
#pragma GCC optimize(2)
#include<bits/stdc++.h>
#define ll long long
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
struct in{
int l,r,sum;
}s[maxn*];
int a[maxn],rt[maxn],N,M,cnt;
void add(int &Now,int L,int R,int pos,int v)
{
if(!Now) Now=++cnt; s[Now].sum+=v;
if(L==R) return ;int Mid=(L+R)>>;
if(pos<=Mid) add(s[Now].l,L,Mid,pos,v);
else add(s[Now].r,Mid+,R,pos,v);
}
void Add(int x,int pos,int v)
{
while(x<=N){
add(rt[x],,N,pos,v);
x+=(-x)&x;
}
}
int query(int Now,int L,int R,int l,int r)
{
if(!Now||s[Now].sum==) return ;
if(l<=L&&r>=R) return s[Now].sum;
int Mid=(L+R)>>,res=;
if(l<=Mid) res+=query(s[Now].l,L,Mid,l,r);
if(r>Mid) res+=query(s[Now].r,Mid+,R,l,r);
return res;
}
int Query(int x,int L,int R)
{
if(L>R||x==) return ;
int res=; while(x){
res+=query(rt[x],,N,L,R);
x-=(-x)&x;
} return res;
}
void read(int &x){
x=; char c=getchar();
while(c>''||c<'') c=getchar();
while(c>=''&&c<='') x=x*+c-'',c=getchar();
}
int main()
{
scanf("%d%d",&N,&M);
rep(i,,N) {
read(a[i]);
if(a[i]!=a[i-]) Add(i,a[i],);
}
int opt,pos,L,R,x,y;
while(M--){
read(opt);
if(opt==){
read(L); read(R); read(x); read(y);
int ans=Query(R,x,y)-Query(L-,x,y);
if(a[L]==a[L-]&&a[L]<=y&&a[L]>=x) ans++;
printf("%d\n",ans);
}
else {
read(pos); read(x);
if(a[pos]==x) continue;
if(a[pos]!=a[pos-]) Add(pos,a[pos],-);
if(pos+!=N&&a[pos+]!=a[pos]) Add(pos+,a[pos+],-);
a[pos]=x;
if(a[pos]!=a[pos-]) Add(pos,a[pos],);
if(pos+!=N&&a[pos+]!=a[pos]) Add(pos+,a[pos+],);
}
}
return ;
}

CDQ:700ms。

/*
2019南昌网络赛I:
*/
#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
struct in{
int opt,x,y,z,id;
//opt=0是修改,否则是查询。
//opt=1表示时间为x,查询[1,x],[y,z]的矩形面积
//时间为第一维,x为第二维,y到z为第三维
}s[maxn<<],q[maxn<<];
int c[maxn],ans[maxn],tot,Q;
int sum[maxn],N,M;
void add(int x,int val)
{
for(int i=x;i<=N;i+=(-i)&i) sum[i]+=val;
}
int query(int x){
int res=;
for(int i=x;i;i-=(-i)&i) res+=sum[i];
return res;
}
void CDQ(int y,int z,int L,int R) //x在[y,z]区间,操作在[L,R]。 不停地对x进行分治,并把[L,R]进行相应的划分
{
if(L>=R) return ;
if(y>z) return ;
if(y==z){ //特殊的一行
rep(i,L,R) {
if(!s[i].opt) add(s[i].y,s[i].z);
if(s[i].opt!=) ans[s[i].id]+=s[i].opt*(query(s[i].z)-query(s[i].y-));
}
rep(i,L,R) if(!s[i].opt) add(s[i].y,-s[i].z);
return ;
}
int Mid=(y+z)>>,F=L,C=L;
rep(i,L,R) {
if(s[i].x<=Mid) C++;
if(!s[i].opt&&s[i].x<=Mid) add(s[i].y,s[i].z);
if(s[i].opt!=&&s[i].x>Mid) ans[s[i].id]+=s[i].opt*(query(s[i].z)-query(s[i].y-));
}
rep(i,L,R) if(!s[i].opt&&s[i].x<=Mid) add(s[i].y,-s[i].z);
rep(i,L,R) if(s[i].x<=Mid) q[F++]=s[i]; else q[C++]=s[i];
rep(i,L,R) s[i]=q[i];
CDQ(y,Mid,L,F-); CDQ(Mid+,z,F,R);
}
int main()
{
scanf("%d%d",&N,&M);
rep(i,,N) {
scanf("%d",&c[i]);
if(c[i]!=c[i-]) s[++tot]=in{,i,c[i],,};
}
int opt,L,R,x,y;
rep(i,,M){
scanf("%d",&opt);
if(opt&){
scanf("%d%d",&x,&y);
if(y==c[x]) continue;
if(c[x]!=c[x-]) s[++tot]=in{,x,c[x],-,};
if(x<N&&c[x]!=c[x+]) s[++tot]=in{,x+,c[x+],-,};
c[x]=y;
if(c[x]!=c[x-]) s[++tot]=in{,x,c[x],,};
if(x<N&&c[x]!=c[x+]) s[++tot]=in{,x+,c[x+],,};
}
else {
scanf("%d%d%d%d",&L,&R,&x,&y); Q++;
s[++tot]=in{,R,x,y,Q};
s[++tot]=in{-,L,x,y,Q};
if(c[L]>=x&&c[L]<=y) ans[Q]++;
}
}
CDQ(,N,,tot);
rep(i,,Q) printf("%d\n",ans[i]);
return ;
}

2019南昌网络赛I:Yukino With Subinterval(CDQ) (树状数组套主席树)的更多相关文章

  1. 2019 ICPC 南昌网络赛I:Yukino With Subinterval(CDQ分治)

    Yukino With Subinterval Yukino has an array a_1, a_2 \cdots a_na1,a2⋯*a**n*. As a tsundere girl, Yuk ...

  2. 2019南昌网络赛-I. Yukino With Subinterval 线段树套树状数组,CDQ分治

    TMD...这题卡内存卡的真优秀... 所以以后还是别用主席树的写法...不然怎么死的都不知道... 树套树中,主席树方法开权值线段树...会造成空间的浪费...这道题内存卡的很紧... 由于树套树已 ...

  3. 2019icpc徐州现场赛 H Yuuki and a problem (树状数组套主席树)

    题意 2e5的数组,q个操作 1.将\(a[x]\)改为y 2.求下标l到r内所有的\(a[i]\)通过加法不能构成的最小的值 思路 通过二操作可以知道需要提取l到r内的值及其数量,而提取下标为l到r ...

  4. 2019南昌网络赛  I. Yukino With Subinterval 树状数组套线段树

    I. Yukino With Subinterval 题目链接: Problem Descripe Yukino has an array \(a_1, a_2 \cdots a_n\). As a ...

  5. 13年山东省赛 Boring Counting(离线树状数组or主席树+二分or划分树+二分)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud 2224: Boring Counting Time Limit: 3 Sec   ...

  6. ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval

    ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval 题目大意:给一个长度为n,值域为[1, n]的序列{a},要求支持m次操作: 单点修改 1 pos val 询 ...

  7. ACM-ICPC 2019南昌网络赛F题 Megumi With String

    ACM-ICPC 南昌网络赛F题 Megumi With String 题目描述 给一个长度为\(l\)的字符串\(S\),和关于\(x\)的\(k\)次多项式\(G[x]\).当一个字符串\(str ...

  8. 2019南昌网络赛 hello 2019

    这道题和一道2017,2016的类似. A string t is called nice if a string “2017” occurs in t as a subsequence but a ...

  9. 2019南昌网络赛G. tsy's number

    题意:\(\sum_{i=1}^n\sum_{j=1}^n\sum_{k=1}^n\frac{\phi(i)*\phi(j^2)*\phi(k^3)}{\phi(i)*\phi(j)*\phi(k)} ...

随机推荐

  1. sonatype nexus安装教程

    1. 安装nexus前需要先安装maven.(详见jdk安装教程)2. 将nexus-2.0.2.rar放到d:\teamwork中,点击右键,解压到当前文件夹中.其中包含两个文件夹:nexus,so ...

  2. oracle--JOB任务

    1.创建一张测试表 -- Create table create table A8 ( a1 VARCHAR2(500) ) tablespace TT1 pctfree 10 initrans 1 ...

  3. IOI 2013 袋熊(线段树+分块+决策单调性)

    题意 http://www.ioi2013.org/wp-content/uploads/tasks/day1/wombats/Wombats%20zh%20(CHN).pdf 思路 ​ 我们设矩形的 ...

  4. Comet OJ - Contest #13-C2

    Comet OJ - Contest #13-C2 C2-佛御石之钵 -不碎的意志-」(困难版) 又是一道并查集.最近做过的并查集的题貌似蛮多的. 思路 首先考虑,每次处理矩形只考虑从0变成1的点.这 ...

  5. Visual Studio 2019(VS2019)正式版注册码秘钥

    Visual Studio 2019 EnterpriseBF8Y8-GN2QH-T84XB-QVY3B-RC4DF Visual Studio 2019 ProfessionalNYWVH-HT4X ...

  6. 【网络知识之四】HTTP/2

    一.HTTP/1.1存在的问题 1.TCP 连接数限制2.线头阻塞 (Head Of Line Blocking) 问题3.Header 内容多,而且每次请求 Header 不会变化太多,没有相应的压 ...

  7. pyqt中pyrcc和pyuic的使用

    一.pyrcc的使用 1.1 作用 将资源文件转换成py文件,并在主程序引入 1.2 资源文件编写说明 新建resource.qrc,代码如下: <!DOCTYPE RCC><RCC ...

  8. java基础之----cookie,session,jwt

    概要 web中为什么要引入cookie.session机制,为了验证用户的身份,验证用户的身份是为了系统的安全,那如果是系统和系统之间的API调用怎么办呢?因为系统之间调用往往是没有用户系统的(用户系 ...

  9. springboot 远程调试

    首先以调试模式启动编译好的jar包,监听端口为5005 java -jar -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,addre ...

  10. 一个简单 System.Threading.Tasks.Dataflow.TransformBlock 示例

    直接贴代码了: using System; using System.Collections.Generic; using System.IO; using System.Threading.Task ...