CF559B Equivalent Strings TJ
前言
正解:模拟,递归。
考试的 T4,还是想复杂了 qwq。
这题不要用 STL,容易 \(\texttt{TLE}\)!!
题意简述
翻译够简了。
对了给一下样例解释的翻译:
第一个样例的第一组测试数据中,对于 \(a=aaba\) 和 \(b=abaa\),可以分成 \(a1=aa,a2=ba,b1=ab,b2=aa\);其中 \(a1\) 和 \(b2\) 全等。对于 \(a=ba\) 和 \(b=ab\),可以分成 \(a1=b,a2=a,b1=a,b2=b\);其中 \(a1\) 和 \(b2\) 全等,\(a2\) 和 \(b1\) 全等。所以 \(aaba\) 和 \(abaa\) 相似。
第一个样例的第二组测试数据中,\(aabb\) 和 \(abab\) 不满足相似。
第一个样例的第一组测试数据中,对于 $a=aaba$ 和 $b=abaa$,可以分成 $a1=aa,a2=ba,b1=ab,b2=aa$;其中 $a1$ 和 $b2$ 全等。对于 $a=ba$ 和 $b=ab$,可以分成 $a1=b,a2=a,b1=a,b2=b$;其中 $a1$ 和 $b2$ 全等,$a2$ 和 $b1$ 全等。所以 $aaba$ 和 $abaa$ 相似。
第一个样例的第二组测试数据中,$aabb$ 和 $abab$ 不满足相似。
分析
鉴于数据的特殊性 (简称水),我们可以直接按照题意递归即可。
因为输入的是两个字符串,而每次递归都需要两个新的字符串,而这两个新的字符串都是在以前的字符串上截取一段形成的。所以,我们根本不需要传字符串,只需要传在输入的字符串中截取的部分开始、结束的下标即可。
当然,因为每次判断都要传两个字符串,所以需要有两对参数,这里,\(l1,r1\) 代表第一个字符串(从输入的第一个字符串中截取),\(l2,r2\) 代表第二个字符串(从输入的第二个字符串中截取)。
首先,两个不同的判断条件打成两个函数 \(\operatorname{f1}\) 和 \(\operatorname{f2}\),分别判断奇数和偶数字符串长度的相似判定。
\(\operatorname{f1}\) 的实现是很简单的,只需要逐字判断是否相等即可。
不过需要注意细节,在计算字符串的长度时,不需要 \(+1\)。具体原因:本来计算长度的时候是要 \(+1\) 的,但是因为 \(l1\) 和 \(l2\) 已经提供了字符串开始的地方,所以我们在这两个数的基准上加的数就是从 \(0\sim r1-l1\) 共 \(r1-l1+1\) 个数字,就不需要 \(+1\) 了。
具体函数如下:
bool f1(int l1,int r1,int l2,int r2){
int t=r1-l1; //计算需要枚举判断的长度
for(int i=0;i<=t;i++) if(a[l1+i]!=b[l2+i]) return 0; //不一样直接返回
return 1; //所有的都一样
}
接着分析较难的递归函数 \(\operatorname{f2}\)。这个函数也是我们在主函数中调用的函数。
首先看传过来的字符串长度是奇数还是偶数。如果是奇数,直接返回 \(\operatorname{f1}\) 的判断就可以了。
如果是偶数,那么就需要判断一分为二之后是否相似。定义两个变量 \(mid1,mid2\) 分别表示两个字符串中间的下标,也就是分开的地方(注意这两个变量表示的是分开后前面那个字符串的最后一个元素),接着根据题意模拟即可,因为有两组配对,所以两组都要判断。注意先 && 再 ||。
这个地方容易打错,记得好好检查。
(对了提醒大家一定要记得不要把函数名给打掉了,我就是这么错的 qwq。)
\(\operatorname{f2}\) 的代码如下(别在意多余的空格,因为放一个框框里怕是有点不美观,我格式化了一下代码):
bool f2(int l1, int r1, int l2, int r2) {
if ((r1 - l1 + 1) & 1)
return f1(l1, r1, l2, r2);
int mid1 = (l1 + r1) >> 1, mid2 = (l2 + r2) >> 1;
return f2(l1, mid1, l2, mid2) && f2(mid1 + 1, r1, mid2 + 1, r2) ||
f2(l1, mid1, mid2 + 1, r2) && f2(mid1 + 1, r1, l2, mid2);
}
最后写好主函数,就可以把这道题切了 qwq。
不要做一些不道德的行为,洛谷的管理员会让你挂上牌子/xyx。
\(Code\)
//格式化了下代码哈
#include <bits/stdc++.h>
using namespace std;
char a[200005], b[200005];
int len;
bool f1(int l1, int r1, int l2, int r2) {
int t = r1 - l1;
for (int i = 0; i <= t; i++)
if (a[l1 + i] != b[l2 + i])
return 0;
return 1;
}
bool f2(int l1, int r1, int l2, int r2) {
if ((r1 - l1 + 1) & 1)
return f1(l1, r1, l2, r2);
int mid1 = (l1 + r1) >> 1, mid2 = (l2 + r2) >> 1;
return f2(l1, mid1, l2, mid2) && f2(mid1 + 1, r1, mid2 + 1, r2) ||
f2(l1, mid1, mid2 + 1, r2) && f2(mid1 + 1, r1, l2, mid2);
}
int main() {
scanf("%s %s", a + 1, b + 1);
len = strlen(b + 1);
if (f2(1, len, 1, len))
printf("YES\n");
else
printf("NO\n");
return 0;
}
写在最后
题目不难,细节有点 duliu。大家打代码一定一定要注意细节啊 awa。
CF559B Equivalent Strings TJ的更多相关文章
- Equivalent Strings
Equivalent Strings 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=84562#problem/E 题意: 给出 ...
- Codeforces Round #313 (Div. 1) B. Equivalent Strings
Equivalent Strings Problem's Link: http://codeforces.com/contest/559/problem/B Mean: 给定两个等长串s1,s2,判断 ...
- Codeforces Round #313 (Div. 2) D. Equivalent Strings
D. Equivalent Strings Time Limit: 2 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/559/ ...
- Codeforces Round #313 (Div. 1) B. Equivalent Strings DFS暴力
B. Equivalent Strings Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/559 ...
- Equivalent Strings (字符串相等?)
Equivalent Strings E - 暴力求解.DFS Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I ...
- Codeforces 559B - Equivalent Strings
559B - Equivalent Strings 思路:字符串处理,分治 不要用substr(),会超时 AC代码: #include<bits/stdc++.h> #include&l ...
- Codeforces Round #313 D. Equivalent Strings(DFS)
D. Equivalent Strings time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- Codeforces Round #313 (Div. 2) 560D Equivalent Strings(dos)
D. Equivalent Strings time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- 暴力求解——Equivalent Strings
Submit Status Description Today on a lecture about strings Gerald learned a new definition of string ...
随机推荐
- .Net Core with 微服务 - Elastic APM
上一次我们介绍了Seq日志聚合组件.这次要给大家介绍的是Elastic APM ,一款应用程序性能监控组件.APM 监控围绕对应用.服务.容器的健康监控,对接口的调用链.性能进行监控.在我们实施微服务 ...
- 『心善渊』Selenium3.0基础 — 8、使用CSS选择器定位元素
目录 1.CSS选择器介绍 2.CSS选择器定位语法 3.Selenium中使用CSS选择器定位元素 (1)通过属性定位元素 (2)通过标签定位元素 (3)通过层级关系定位元素 (4)通过索引定位元素 ...
- 《手把手教你》系列基础篇(五)-java+ selenium自动化测试- 创建首个自动化脚本(详细教程)
1.简介 前面几篇宏哥介绍了两种(java和maven)环境搭建和三大浏览器的启动方法,这篇文章宏哥将要介绍第一个自动化测试脚本.前边环境都搭建成功了,浏览器也驱动成功了,那么我们不着急学习其他内容, ...
- excel VBA数组运用
Sub a()Dim i人数 As Integer'定义变量Dim i考试成绩() As Integer'定义数组Dim i As Integer'定义变量i人数 = InputBox("输 ...
- 使用Oracle SQL Developer报错:Unable to find a Java Virtual Machine
1.环境 win7 x64,oracle 11g r2,jdk6 x64 2.问题 第一次启动Oracle SQL Developer的时候会让我们填写java.exe的路径,我在jdk安装目录下的b ...
- layui 修改表格边框颜色
/*设置不可编辑时字体颜色*/ .layui-disabled, .layui-disabled:hover { color: #101010 !important; background-color ...
- 资源:VMware秘钥许可证
一. 激活密钥 YG5H2-ANZ0H-M8ERY-TXZZZ-YKRV8 UG5J2-0ME12-M89WY-NPWXX-WQH88 UA5DR-2ZD4H-089FY-6YQ5T-YPRX6 GA ...
- Java实验项目三——采用面向对象的方式设计线性表
Program: 采用面向对象的方法设计一个线性表,目的是为其他需要用线性表的应用提供线性表对象. 1.list包中,定义线性表类 1 /* 2 * Description:定义线性表类 3 * 4 ...
- 网络编程+Python
一.网络编程(模块:socket,from socket import *): 1. 网络层的IP地址可以唯一标识网络中的主机,传输层的"协议+端口"则可以唯一标识主机中应用程序( ...
- TestComplete 64位和32位之间的区别
在64位系统上,有两种版本的TestComplete:32位和64位.本主题描述了TestComplete x64及其32位版本之间的区别.关于TestComplete x64启动TestComple ...