LeetCode解题之Scramble String


原题

一个字符串能够拆分成两个都不为空的子字符串,而子字符串(长度大于等于二)也能够不断这样拆分下去。如今能够随意交换拆分出来两部分的位置来改变字符串中字符的顺序。推断两个字符是否能通过这样的方式相互转换。

注:这道题比較难用语言描写叙述,能够參见原题中的图例

原题请点 这里

注意点:

  • 给的两个字符串的长度相等

样例:

输入: s1 = “rgtae”, s2 = “great”

输出: True (“rgtae”->”grtae”->”greta”->”great”)

解题思路

对三维动态规划还不是非常熟练,偷懒用了最简单的递归方式,以后会补上动态规划解法。

要推断两个字符S和T是否能转化,先把它们各自分为两部分。假设S的前半部分和T的前半部分能转换,它们的后半部分也能转换,说明它们就能转换;但也有可能S的前半部分和后半部分是在最后一交换中转换回来的。也就是S的前半部分和T的后半部分能够转换。而T的前半部分和S的后半部分能够转换相同能够达到目的。还能够在我代码的基础上再做一些优化。如提前推断两个要转化的字符串中各字符的数目是否相等来进行剪枝,来降低没实用的递归。经过剪枝的递归算法的执行速度还是非常快的。

AC源代码

from collections import defaultdictclass Solution(object):def isScramble(self, s1, s2):""":type s1: str:type s2: str:rtype: bool"""if s1 == s2:return Truecount1 = defaultdict(int)count2 = defaultdict(int)for e1, e2 in zip(s1, s2):count1[e1] += 1count2[e2] += 1if count1 != count2:return Falsefor i in range(1, len(s1)):if self.isScramble(s1[:i], s2[:i]) and self.isScramble(s1[i:], s2[i:]) \or self.isScramble(s1[:i], s2[-i:]) and self.isScramble(s1[i:], s2[:len(s2) - i]):return Truereturn False

欢迎查看我的Github (https://github.com/gavinfish/LeetCode-Python) 来获得相关源代码。

LeetCode Scramble String相关推荐

  1. 【To Understand !!! DP or 递归】LeetCode 87. Scramble String

    LeetCode 87. Scramble String 参考链接:[1]https://blog.csdn.net/makuiyu/article/details/44926439 [2]http: ...

  2. 【细节实现题】LeetCode 8. String to Integer (atoi)

    LeetCode 8. String to Integer (atoi) Solution1:我的答案 参考链接:http://www.cnblogs.com/grandyang/p/4125537. ...

  3. LeetCode 8. String to Integer (atoi)(字符串)

    LeetCode 8. String to Integer (atoi)(字符串) LeetCode 8 String to Integer atoi字符串 问题描述 解题思路 参考代码 By Sca ...

  4. Scramble String -- LeetCode

    原题链接: http://oj.leetcode.com/problems/scramble-string/  这道题看起来是比較复杂的,假设用brute force,每次做分割,然后递归求解,是一个 ...

  5. 【LeetCode】87. Scramble String

    题目: Given a string s1, we may represent it as a binary tree by partitioning it to two non-empty subs ...

  6. [leetcode] 根据String数组构造TreeNode,用于LeetCode树结构相关的测试用例

    LeetCode 跟树结构相关的题目的测试用例中大多是通过String数组来构造树.例如{2,#,3,#,4,#,5,#,6},可以构造出如下的树(将树结构逆时针选择90度显示): 6        ...

  7. LeetCode Rearrange String k Distance Apart

    原题链接在这里:https://leetcode.com/problems/rearrange-string-k-distance-apart/description/ 题目: Given a non ...

  8. LeetCode Interleaving String

    原题链接在这里:https://leetcode.com/problems/interleaving-string/ 这是一道DP题,用boolean数组dp维护历史数据,dp[i][j]表示长度为i ...

  9. LeetCode 443 String Compression(双指针)

    问题:给出一个字符串,对其压缩.对于连续出现的字符,用字符+出现次数来表示.单个情况时,数字1可以省略. 思路:使用ancher来表示检查的起始位置,遍历时记录不相同的位置,此时作压缩替换. 具体代码 ...

最新文章

  1. Pymol BioPython | PDB文件中氨基酸序列的提取
  2. 20172311『Java程序设计』课程 结对编程练习_四则运算第一周阶段总结
  3. 笔记-信息系统开发基础-架构设计-软件架构主要职责
  4. DS博客作业01--日期抽象数据类型设计与实现
  5. VBA 脚本快速copyExcel单元格的格式
  6. 基于visual Studio2013解决面试题之1109全排列
  7. [渝粤教育] 西南科技大学 理论力学 在线考试复习资料(1)
  8. 微信抢号软件_快来抢微信靓号!微信小商店正式上线
  9. 高等数学(第七版)同济大学 习题4-1 个人解答
  10. 纠删码(Erasure Code)及其演进LRC(Locally Repairable Codes)原理讲解
  11. 商品期货跨期套利实战笔记
  12. Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day39】—— 数据库6
  13. blockchain 初步了解区块链
  14. 顺序表练习(三):对称矩阵的压缩储存
  15. 学计算机在职硕士,计算机在职研究生的学习方式有哪些?
  16. 《挑战程序设计竞赛》 读后感(转载)
  17. Java自动生成日历,移除节假日和周六日
  18. 1677 treecnt(贡献)
  19. Dr.com 新版 Ver 5.2.0 本地 密码 读取 查看 破解
  20. redis集群伸缩【转】

热门文章

  1. 计算项目中的代码行数:Count the Lines of Code (LOC)
  2. ClickHouse系列教程四:允许远程连接 allow remote access
  3. 如何给机房的服务器安装系统,云机房服务器系统安装
  4. python tornado入门_Tornado入门
  5. windows链接Linux的pgsql,postgreSQL在CMD里怎么连接
  6. 这一篇让你真正理解Mysql的四种隔离级别
  7. vonr信令流程_SA EPS FallBack重要信令节点
  8. python爬取公众号推荐_python爬搜狗微信获取指定微信公众号的文章
  9. 老大说要自动化测试,我是怎么做的可以看看
  10. 关于Linux用户管理相关研究-------(二)