LeetCode第八十七题—扰乱字符串
自己代码的开源仓库:click here 欢迎Star和Fork :)
题目描述
使用下面描述的算法可以扰乱字符串 s 得到字符串 t :
如果字符串的长度为 1 ,算法停止
如果字符串的长度 > 1 ,执行下述步骤:
在一个随机下标处将字符串分割成两个非空的子字符串。即,如果已知字符串 s ,则可以将其分成两个子字符串 x 和 y ,且满足 s = x + y 。
随机 决定是要「交换两个子字符串」还是要「保持这两个子字符串的顺序不变」。即,在执行这一步骤之后,s 可能是 s = x + y 或者 s = y + x 。
在 x 和 y 这两个子字符串上继续从步骤 1 开始递归执行此算法。
给你两个 长度相等 的字符串 s1 和 s2,判断 s2 是否是 s1 的扰乱字符串。如果是,返回 true ;否则,返回 false 。
1 | 示例 1: |
递归图示
举递归的一种情况示例,其他的类似:
对于交换的情况,比如abc 和 bac 存在a和c匹配 bc和ba匹配的情况。
代码
效率爆炸。
1 | class Solution(object): |