中文题意:

给你两个长度为 \(n\) 的01串 \(s,f,\)有 \(q\) 次询问。

每次询问有区间 \([\ l,r\ ]\) ,如果 \([\ l,r\ ]\) 同时包含\(0\)和\(1\),则询问终止,否则你可以将区间\([\ l,r\ ]\) 内严格小于 \(len_{lr}\) 的数字。

问是否可以使得询问不终止,且经过 \(q\) 次询问后可以将\(s\)改为\(f\)。

前置知识:

线段树

没了

思路:

发现没法正序推过去(反正我不会),考虑根据询问逆推。

那么对于 \(f\) ,和 \(q_{1},q_{2}\)···\(q_{n}\) ,用 \(l_{i},r_{i}\) 来表示 \(q_{i}\) , \(s_{i}\)表示经过前 \(i\) 次询问后的字符串 \(s\) 。

对于第 \(n\) 次询问,当且仅当 \(s_{n-1}\)中的 \([l_{n},r_{n}]\) 全为 \(k\) ( \(k\) \(\in\) \((0,1)\) ) ,\(f\) 在 \([l_{n},r_{n}]\) 内(\(k\oplus 1\))的数量\(num_{k\oplus 1}\) \(<\) \(len_{lr}\) 时,

\(s_{n-1}\) 可转化 \(f\) 。

那么,我们可以从 \(f\) 开始向前遍历询问。对于 \([l_{n},r_{n}]\) 将 \([l_{n},r_{n}]\) 内数量较少的数字改为另一个数字。

显然,当 \([l_{n},r_{n}]\) 内 \(num_{1} = num_{0}\) 时,询问会终止,因为改变量必须严格小于区间长度的一半。

遍历到最后判断 \(s\) 和经过转化的 \(f\) 是否相同就行了。

做法:

对于区间,查询和改变问题,我们可以用线段树在 \(log\ n\) 的复杂度下解决。

首先对于 \(f\) 建立线段树,维护区间内 \(1\) 的数量。

对于区间修改,建立 \(lazy\) 标记,\(-1\) 表示不变,\(0\) 表示 \(lazy\) 下的区间全为\(0\),\(1\) 表示 \(lazy\) 下的区间全为\(1\)。

\(pusdown\) 操作:

inline void pushdown(int p,int l,int r)
{
if(laz[p]==-1)//未被标记跳过
return ;
int mid=(l+r)>>1;
if(laz[p])//标记为1
{
tr[p<<1]=(mid-l+1);
tr[p<<1|1]=(r-mid);
laz[p<<1]=laz[p<<1|1]=1;
laz[p]=-1;
return ;
}
tr[p<<1]=tr[p<<1|1]=0;//标记为0
laz[p<<1]=laz[p<<1|1]=0;
laz[p]=-1;
}

剩下的就是线段树的基本操作了。

Code:

#include<bits/stdc++.h>
#define N 240000
using namespace std; int t,n,q;
char s[N],f[N];
int ql[N],qr[N],tr[N<<2],laz[N<<2]; inline int read()
{
char a=0;int w=1,x=0;
while(a<'0'||a>'9'){if(a=='-')w=-1;a=getchar();}
while(a<='9'&&a>='0'){x=(x<<3)+(x<<1)+(a^48);a=getchar();}
return x*w;
} inline void pushdown(int p,int l,int r)
{
if(laz[p]==-1)//未被标记跳过
return ;
int mid=(l+r)>>1;
if(laz[p])//标记为1
{
tr[p<<1]=(mid-l+1);
tr[p<<1|1]=(r-mid);
laz[p<<1]=laz[p<<1|1]=1;
laz[p]=-1;
return ;
}
tr[p<<1]=tr[p<<1|1]=0;//标记为0
laz[p<<1]=laz[p<<1|1]=0;
laz[p]=-1;
} void build(int p,int l,int r)//建树
{
laz[p]=-1;
if(l==r)
{
tr[p]=(f[l]^48);
return ;
}
int mid=(l+r)>>1;
build(p<<1,l,mid);
build(p<<1|1,mid+1,r);
tr[p]=tr[p<<1]+tr[p<<1|1];
} int que(int p,int l,int r,int L,int R)//查询1的数量
{
if(L<=l&&r<=R)
return tr[p];
pushdown(p,l,r);
int mid=(l+r)>>1;
int ans=0;
if(mid>=L)
ans+=que(p<<1,l,mid,L,R);
if(mid<R)
ans+=que(p<<1|1,mid+1,r,L,R);
return ans;
} void modify(int p,int l,int r,int L,int R,int opt)//区间修改
{
if(L<=l&&r<=R)
{
tr[p]=opt*(r-l+1);
laz[p]=opt;
return ;
}
pushdown(p,l,r);
int mid=(l+r)>>1;
if(mid>=L)
modify(p<<1,l,mid,L,R,opt);
if(mid<R)
modify(p<<1|1,mid+1,r,L,R,opt);
tr[p]=tr[p<<1]+tr[p<<1|1];
} int main()
{
t=read();
while(t--)
{
n=read();
q=read();
int flag=1;
scanf("%s%s",(s+1),(f+1));
for(register int i=1;i<=q;i++)
{
ql[i]=read();
qr[i]=read();
}
build(1,1,n);
for(register int i=q;i>=1;i--)
{
int len=qr[i]-ql[i]+1;//区间长度
int num=que(1,1,n,ql[i],qr[i]);//查询区间内1的数量
if( num==len-num )//区间内0的数量为 len-num , 0和1数量相同时不可能成立
{
flag=0;
break;
}
modify(1,1,n,ql[i],qr[i],num>(len-num) );//区间修改
}
if(!flag)
{
printf("NO\n");
continue;
}
for(register int i=1;i<=n;i++)
{
int num=que(1,1,n,i,i);//取出经过q次询问后f的第i位
if(num!=(s[i]^48))//判断f和s是否相等,不相等退出
{
flag=0;
break;
}
}
if(!flag)
{
printf("NO\n");
continue;
}
printf("YES\n");
}
return 0;
}

Codeforces #698 (Div. 2) E. Nezzar and Binary String 题解的更多相关文章

  1. Codeforces 862D. Mahmoud and Ehab and the binary string (二分)

    题目链接:Mahmoud and Ehab and the binary string 题意: 一道交互题,首先给出一个字符串的长度l.现在让你进行提问(最多15次),每次提问提出一个字符串,会返回这 ...

  2. codeforces D. Mahmoud and Ehab and the binary string(二分)

    题目链接:http://codeforces.com/contest/862/submission/30696399 题解:这题一看操作数就知道是二分答案了.然后就是怎么个二分法,有两种思路第一种是找 ...

  3. Codeforces 862D. Mahmoud and Ehab and the binary string 【二分】(交互)

    <题目链接> 题目大意: 有一个长度为n(n<1000)的01串,该串中至少有一个0和一个1,现在由你构造出一些01串,进行询问,然后系统会给出你构造的串与原串的   Hamming ...

  4. Codeforces.862D.Mahmoud and Ehab and the binary string(交互 二分)

    题目链接 \(Description\) 有一个长为\(n\)的二进制串,保证\(01\)都存在.你可以询问不超过\(15\)次,每次询问你给出一个长为\(n\)的二进制串,交互库会返回你的串和目标串 ...

  5. Codeforces Round #598 (Div. 3) D. Binary String Minimizing 贪心

    D. Binary String Minimizing You are given a binary string of length n (i. e. a string consisting of ...

  6. D2. Kirk and a Binary String (hard version) D1 Kirk and a Binary String (easy version) Codeforces Round #581 (Div. 2) (实现,构造)

    D2. Kirk and a Binary String (hard version) time limit per test1 second memory limit per test256 meg ...

  7. Codeforces Round #598 (Div. 3) D. Binary String Minimizing

    You are given a binary string of length nn (i. e. a string consisting of nn characters '0' and '1'). ...

  8. Educational Codeforces Round 94 (Rated for Div. 2) String Similarity、RPG Protagonist、Binary String Reconstruction、Zigzags 思维

    题目链接:String Similarity 题意: 首先题目定义了两个串的相似(串的构成是0.1),如果两个串存在对于一个下标k,它们的值一样,那么这两个串就相似 然后题目给你一个长度为2n-1的串 ...

  9. Codeforces #344 Div.2

    Codeforces #344 Div.2 Interview 题目描述:求两个序列的子序列或操作的和的最大值 solution 签到题 时间复杂度:\(O(n^2)\) Print Check 题目 ...

随机推荐

  1. Spring Data Cache

    Spring Data Cache注解使用 方法是一个对象,使用对象中的属性,如ID,作为cache key RedisConnection超时设置 参考 SpringBoot使用Redis缓存

  2. Qt学习笔记-制作一个计算器-对话框Message Box

    在做计算器的前提先做一个加法器. 设计界面. 在点击计算的时候,获取前两个输入框中的数据相加后显示在第三个输入框. toInt是将字符串转换为数字.number静态函数是将数字转化为字符串. 加法器已 ...

  3. 备战金三银四!一线互联网公司java岗面试题整理:Java基础+多线程+集合+JVM合集!

    前言 回首来看2020年,真的是印象中过的最快的一年了,真的是时间过的飞快,还没反应过来年就夸完了,相信大家也已经开始上班了!俗话说新年新气象,马上就要到了一年之中最重要的金三银四,之前一直有粉丝要求 ...

  4. .NET 云原生架构师训练营(模块二 基础巩固 MongoDB 聚合)--学习笔记

    2.5.5 MongoDB -- 聚合 排序 索引类型 创建索引 排序 // 升序 db.getCollection('author').find({}).sort({"age": ...

  5. el-input限制只能输入数字(开发小记)

    输入框中限制通常有三种处理方法 第一种:设置type属性(不推荐) 设置type属性为number,text等等,此方法输入框的后面会有不必要样式出现 <el-input type=" ...

  6. 敏捷史话(二):Scrum社区的悲剧性损失——Mike Beedle

    2018年3月23日,在美国的芝加哥发生了一起意外刺杀事件.一名男子刺杀了一位首席执行官,而这位不幸的首席执行官就是<敏捷宣言>的合著者--Mike Beedle.Mike 的这场意外令 ...

  7. Akka Typed 官方文档之随手记

    ️ 引言 近两年,一直在折腾用FP与OO共存的编程语言Scala,采取以函数式编程为主的方式,结合TDD和BDD的手段,采用Domain Driven Design的方法学,去构造DDDD应用(Dom ...

  8. ABP vNext 审计日志获取真实客户端IP

    背景 在使用ABP vNext时,当需要记录审计日志时,我们按照https://docs.abp.io/zh-Hans/abp/latest/Audit-Logging配置即可开箱即用,然而在实际生产 ...

  9. 【Sphinx】 为Python自动生成文档

    sphinx 前言 Sphinx是一个可以用于Python的自动文档生成工具,可以自动的把docstring转换为文档,并支持多种输出格式包括html,latex,pdf等 开始 建一个存放文档的do ...

  10. AI智能皮肤测试仪助力美业数字化营销 实现门店与用户双赢局面

    当皮肤遇到AI智能,会有怎么样的火花呢?随着生活水平的提升,人们对肌肤保养护理的需求也越来越高,人要美,皮肤养护也要更精准,数字化必将成为美业发展的新契机.新机遇下肌肤管家SkinRun为美业客户提供 ...