Equivalent Strings

Problem's Link:   http://codeforces.com/contest/559/problem/B 


Mean:

给定两个等长串s1,s2,判断是否等价。

等价的含义为:

若长度为奇数,则必须是相同串。

若长度是偶数,则将两串都均分成长度为原串一半的两个子串l1,r1和l2,r2,其中l1和l2等价且r1和r2等价,或者l1和r2等价且l2和r1等价。

analyse:

直接按照题意模拟写个递归分治就行。
比赛的时候总觉得这样暴力写会TLE,因为算了下大概是4^(log2(n))的复杂度,也就是n^2,所以比赛的时候就想了下,将两个串都按照题意转化为字典序最小串(循环节的最小表示法)然后比较a和b的两个最小表示法是否是相同的即可。
后来想了半天为什么分治到不了4^(log2(n))的复杂度呢?
原因是这样的:我们就按照这个复杂度去构造串。首先,如果要让al和ar比较,bl和br比较,且al和br也比较,ar和bl也比较的话,则必须满足al和bl等价,ar和br不等价,且al和br等价,这样才能保证让ar和bl去比较。然而我们在比较的al和bl的时候,再分治,设al分成了all,alr,bl分成了bll,blr,要想让它再比较4次,则有all和bll等价,alr和blr不等价,alr和bll等价,但因为这个情况下al和bl是等价的,所以必须有alr和bll等价。我们简单的写成
  all = bll
  alr != blr
  alr = bll
  all = blr
然而这4个等式可以推出all = bll = alr = blr,即4个子串任意都能等价,与第二个等式矛盾。这说明无法构造一种串使得复杂度达到4^(log2(n))。实际上,在很多时候递归只进行了三次甚至两次一次就返回了。因此分治的效率也是很高的。当然,最小表示法的复杂度是O(n*log(n))的,那是一定可以过。实际上还是分治的思想,只不过处理上有点不同罢了。

Time complexity: O(N*logN)

Source code: 

/*
* this code is made by crazyacking
* Verdict: Accepted
* Submission Date: 2015-07-22-22.45
* Time: 0MS
* Memory: 137KB
*/
#include <queue>
#include <cstdio>
#include <set>
#include <string>
#include <stack>
#include <cmath>
#include <climits>
#include <map>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
#define  LL long long
#define  ULL unsigned long long
using namespace std;
#define NN 200000+50
char A[NN], B[NN];
int cmp( char x[] , char y[] , int len )
{
     for( int i = 0; i < len; ++i )
           if( x[i] < y[i] ) return -1;
           else if( x[i] > y[i] )return 1;
}

void work( int len, char x[] )
{
     if( len % 2 == 1 ) return ;
     work( len / 2, x );
     work( len / 2, x + len / 2 );
     if( cmp( x, x + len / 2, len / 2 ) > 0 )
           for( int i = 0; i < len / 2; ++i )
                 swap( x[i], x[i + len / 2] );
}
int main()
{
     ios_base::sync_with_stdio( false );
     cin.tie( 0 );
     scanf( "%s %s", A, B );
     int len = strlen( A );
     work( len, B );
     work( len, A );
     if( strcmp( A, B ) == 0 ) puts( "YES" );
     else puts( "NO" );
     return 0;
}
/*

*/

Codeforces Round #313 (Div. 1) B. Equivalent Strings相关推荐

  1. 【打CF,学算法——二星级】Codeforces Round #313 (Div. 2) B. Gerald is into Art(水题)...

    [CF简单介绍] 提交链接:http://codeforces.com/contest/560/problem/B 题面: B. Gerald is into Art time limit per t ...

  2. Codeforces Round #313 (Div. 1) A. Gerald's Hexagon 数学题

    A. Gerald's Hexagon Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/559/p ...

  3. Codeforces Round #313 (Div. 1) C. Gerald and Giant Chess DP

    C. Gerald and Giant Chess Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest ...

  4. Codeforces Round #598 (Div. 3) F. Equalizing Two Strings 思维 + 逆序对

    传送门 文章目录 题意: 思路: 题意: 给你两个长度为nnn的串a,ba,ba,b,每次可以同时翻转a,ba,ba,b中任意一段长度为L(1≤L≤n)L(1\le L\le n)L(1≤L≤n)的子 ...

  5. C. Tyler and Strings(组合数学,树状数组维护前缀和)(Codeforces Round #775 (Div. 1, based on Moscow Open Olympiad i)

    对我来说比较困难的一题了,尝试着自己写了一下,调不出来遂放弃. Codeforces Round #775 (Div. 1, based on Moscow Open Olympiad in Info ...

  6. Codeforces Round FF(Div. 2)

    layout: post title: Codeforces Round FF(Div. 2) author: "luowentaoaa" catalog: true tags: ...

  7. Codeforces Round #644 (Div. 3) F.Spy-string

    Codeforces Round #644 (Div. 3) F.Spy-string 题目链接 You are given n strings a1,a2,-,an: all of them hav ...

  8. Codeforces Round #706 (Div. 2)-A. Split it!-题解

    目录 Codeforces Round #706 (Div. 2)-A. Split it! Problem Description Input Output Sample Input Sample ...

  9. Codeforces Round #710 (Div. 3)个人题解

    Codeforces Round #710 (Div. 3) 文章目录 [Codeforces Round #710 (Div. 3)](https://codeforces.com/contest/ ...

最新文章

  1. 对标以太坊的EOS再火,也拼不过InterValue的区块链4.0
  2. [javascript] 看知乎学习js闭包
  3. 数学之美 系列 12 - 余弦定理和新闻的分类
  4. python能做数据库开发吗_5分钟快速入门,用Python做SQLite数据库开发,附代码适合初学...
  5. 双十一我们在作战室干什么?零点刚过,我偷偷提交了几行代码!
  6. 分析varnish日志
  7. 一篇文章彻底搞清楚Windows系统批处理脚本.bat文件的注释
  8. 零基础学习CAD机械软件:02课CAD软件的启动和退出
  9. python判断三位数水仙花数_Python如何判断一个数字是否为水仙花数
  10. JavaFX源码分析实战:如何设置窗体标题小图标和任务栏图标
  11. PHP实现数字金额轻松转成中文繁体大写
  12. 解读广告投放效果数据
  13. 小学生台灯哪个品牌更护眼?学习专用的护眼台灯品牌
  14. SpringBoot ThreadPoolTaskExecutor异步使用(一)
  15. 使用fbinst生成u盘启动列表大小不能太大
  16. 我的第一个油猴脚本「屏蔽CSDN底下的登录栏」
  17. Match公链官网正式上线,链接Web3加速落地
  18. 这个队列的思路真的好,现在它是我简历上的亮点了。
  19. 一文教会你如何选择远程桌面(五大主流远程软件全面讲解)
  20. xxl-job安装部署

热门文章

  1. 省钱方便网上手机充话费
  2. 针对上上篇博文--仿优酷菜单---的bug修改
  3. CS224n Assignment 2
  4. C/C++-标准输入/输出重定向为文件输入/输出
  5. loadruner中加中Java_Script
  6. 编程题:两个数比较大小,之后用变量t互换。
  7. iOS网络开发之:NSURLConnection
  8. 零售流通ERP系统——基础信息的确立与实施
  9. Spring Cloud 微服务开发系列整理
  10. 0715PHP基础:文件操作