LeetCode-Scramble String

哎,难题又不会做,

思路没有什么难度,

关键是要把问题思考透彻,

要考虑的要点还是挺多的,不容易一下子都考虑到;

我开始的思路是按照树的根去递归的,

这样就必须要没有重复元素,因为需要每次在s2中查找s1中的元素;

怎么说呢,有点考虑的过于specific了,其实直接把字符串分成两部分递归就可以了,

不过需要注意不能漏掉两部分可能次序调换的情况。

 1 class Solution {
 2 public:
 3     bool isScramble(string s1, string s2) {
 4         // Start typing your C/C++ solution below
 5         // DO NOT write int main() function
 6         if (s1.empty() && s2.empty()) {
 7             return true;
 8         }
 9         if (s1 == s2) {
10             return true;
11         }
12         return scramble(s1, 0, s1.size() - 1, s2, 0, s2.size() - 1);
13     }
14     bool scramble(string &s1, int b1, int e1, string &s2, int b2, int e2) {
15         if (!same(s1, b1, e1, s2, b2, e2)) {
16             return false;
17         }
18         int len = e1 - b1 + 1;
19         if (len == 0) {
20             return true;
21         }
22         if (len == 1) {
23             return (s1[b1] == s2[b2]);
24         }
25         for (int i = 0; i < len - 1; ++i) {
26             if ((scramble(s1, b1, b1 + i, s2, b2, b2 + i) && scramble(s1, b1 + i + 1, e1, s2, b2 + i + 1, e2)) || 
27                 (scramble(s1, b1, b1 + i, s2, e2 - i, e2)) && scramble(s1, b1 + i + 1, e1, s2, b2, e2 - i - 1)) {
28                 return true;
29             }
30         }
31         return false;
32     }
33     bool same(string &s1, int b1, int e1, string &s2, int b2, int e2) {
34         vector<int> count(256, 0);
35         for (int i = b1; i <= e1; ++i) {
36             ++count[s1[i]];
37         }
38         for (int i = b2; i <= e2; ++i) {
39             --count[s2[i]];
40         }
41         for (int i = 0; i < 256; ++i) {
42             if (count[i] != 0) {
43                 return false;
44             }
45         }
46         return true;
47     }
48 };

 

转载于:https://www.cnblogs.com/chasuner/p/scramble.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/433150.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在线打开html文件,html是什么文件?html文件怎么打开?

html是什么&#xff1f;html即超文本标记语言&#xff0c;现在大多网页都是html的格式。而所谓的html文件是一种超文本文件&#xff0c;其中超文本可以是图片或音乐等非文字元素&#xff0c;使用很广泛。但是很多用户都不太明白html是什么文件&#xff1f;也不清楚html文件要如…

gsoap使用心得! (win32)

最近换了个工作环境&#xff0c;现在在大望路这边上班&#xff0c;呵&#xff0c;刚上班接到的任务就是熟悉gsoap&#xff01;废话少说&#xff0c;现在开始gSoap学习&#xff01;gSOAP是一个夸平台的&#xff0c;用于开发Web Service服务端和客户端的工具&#xff0c;在Window…

hbase中列簇和列_为什么不建议在hbase中使用过多的列簇

我们知道&#xff0c;hbase表可以设置一个至多个列簇(column families)&#xff0c;但是为什么说越少的列簇越好呢&#xff1f;官网原文&#xff1a;HBase currently does not do well with anything above two or three column families so keep the number of column familie…

html怎么置顶导航栏,css怎么实现滚动页面导航栏固定在顶部

css怎么实现滚动页面导航栏固定在顶部(吸顶效果)功能&#xff1a;当网页向下滚动时&#xff0c;导航栏一直在固定在顶部一、css设置这里主要用到css中position中的relative与fixed&#xff1b;其中relative是生成相对定位的元素&#xff0c;相对于其正常位置进行定位。fixed是生…

numpy读取csv_Numpy——IO操作与数据处理

一、问题&#xff1f;大多数数据并不是我们自己构造的&#xff0c;存在文件当中。我们需要工具去获取&#xff0c;但是Numpy其实并不适合去读取处理数据&#xff0c;这里我们了解相关API&#xff0c;以及Numpy不方便的地方即可。二、Numpy读取genfromtxt(fname[, dtype, commen…

Pydiction : VIM上的PYTHON代码自动补全插件

http://www.vim.org/scripts/script.php?script_id850 1、下载Pydiction其中有4个文件&#xff1a;complete-dict //PYTHON 的KEYWORD集pydiction.pypython_pydiction.vim //让VIM认识PYTHONREADME.txt //说明书 2、把上面的python_pydiction.vim拷到ftplugin 目录下 3、把其它…

android 中radiogroup滑动切换,巧妙实现缺角radiogroup控制多个fragment切换和滑动

在android开发中&#xff0c;用一个radiogroup控制多个fragment切换是十分常见的需求。但是如果fragment是一个ListView&#xff0c;如何保证滑动的时候通过缺角可以看到下面的listview是一个难点。直接上图:(1)完美效果(2)较差效果另外&#xff0c;不妨假设缺角的高度是5dp&am…

java vo转map_JAVA Map转换为Bean或VO

JAVA Map转换为Bean或VOJava.util中的集合类包含Java中某些最常用的类。Map提供了一个更通用的元素存储方法。Map集合类用于存储元素对(称作“键”和“值”)&#xff0c;其中每个键映射到一个值&#xff0c;在java编程中使用的相当之多。但是当我们进行业务逻辑或数据库处理时&…

应用市场中包名(package name)的唯一性

一般的应用商店&#xff0c;在开发者上传应用(APP)的时候&#xff0c;都会对应用的包名进行唯一性的校验。如果此时&#xff0c;用户上传的应用的包名与数据库中的已有的APP的包名一样&#xff0c;那么正常情况下&#xff0c;该应用就不能上传&#xff0c;而弹出提示说&#xf…

linux中线程的挂起与恢复(进程暂停)

今 天 在网上查了一下 linux中对进程的挂起与恢复的实现&#xff0c;相关资料少的可怜&#xff0c;大部分都是粘贴复制。也没有完整详细的代码。故自己整理了一下程序流程为&#xff1a;主线程创建子线程&#xff08;当前子线程状态为stop停止状态&#xff09;&#xff0c;5秒后…

荣耀智慧屏评测 鸿蒙OS加持,荣耀智慧屏评测:鸿蒙OS加持 面向未来的超智能电视...

原标题&#xff1a;荣耀智慧屏评测&#xff1a;鸿蒙OS加持 面向未来的超智能电视 来源&#xff1a;TechWeb.com.cn当华为选择在今年公布鸿蒙OS系统后&#xff0c;很多人都在期待它的庐山真面目。无论是以后非常时期不再受制于人&#xff0c;或是循序渐进将系统过渡给自家设备&a…

c位边上还有什么位_【一点资讯】那些有趣而搞笑的GIF动画:为让出c位,站边上拍照还是谦虚礼貌的 www.yidianzixun.com...

1_为让出c位&#xff0c;站边上拍照&#xff0c;还是谦虚礼貌的&#xff0c;2_最后都吓死我了&#xff01;3_啥情况&#xff1f;4_今年工作太难了&#xff0c;回家种地卖水果吧5_除了电池差了一点&#xff0c;12应该是最完美的手机了吧精选搞笑图文&#xff1a;小王去女朋友家里…

两个有用的minicom命令

minicom执行后&#xff0c;一个屏幕显示的字符有限&#xff0c;如果需要查看之前的串口通讯记录&#xff0c;可以使用Ctrl-A B使用进入串口通讯记录查询模式。如果需要将minicom的串口通讯记录保存到某个文件&#xff0c;可以在minicom刚启动时用Ctrl-A L命令进入串口通讯捕捉模…

2021河南固高高考成绩查询,河南信阳最好的4所高中,前三所学霸如云,看看有没有你的母校?...

河南省信阳市处于豫之南&#xff0c;鄂之北。南边是连绵的群山&#xff0c;北边是广袤的平原。千里淮河&#xff0c;曲折盘旋&#xff0c;它的源头便是这里。都说信阳是一个神奇的地方&#xff0c;一点儿也不为过&#xff0c;狮河穿城而过&#xff0c;周围群山环抱&#xff0c;…

python库读取cif文件_Pymatgen读/写各种文件,pymatgen,读写

pymatgen读/写各种文件pymatgen是材料大数据计算的必备程序包了&#xff0c;其也作为API与materials project对接&#xff0c;可以批量下载自己想要的材料结构、性质&#xff0c;它也提供了大量VASP计算后的数据处理、计算&#xff0c;堪称材料基因组学的神器&#xff01;pymat…

磁盘的磁道(Track)

写这篇文章&#xff0c;主要是为了解决长久以来的一个困惑。由此也可以看出偶以前确实不太聪明。 哈哈(虽然现在仍然还是) 以前见到的很多磁道的示意图都是这样的&#xff1a;注意标线的位置&#xff0c;“指向一条线”&#xff0c;我当时的理解好像是这条线就是磁道。还有的解…

Android SDK Manager 在win8.1上的闪退问题【转载】

全新安装的Windows 8.1的系统&#xff0c;Android SDK&#xff0c;JDK都是最新的版本&#xff0c;但是SDK Manager打开是命令行窗口一闪而过&#xff0c;就再没反映了。 通过搜索&#xff0c;确定了一个问题就是SDK目录tools\lib下有个find_java.bat&#xff0c;本来的作用是查…

centos 卸载_CentOS安装mysql

安装mysql第一步&#xff0c;查看是否安装&#xff1a;rpm -qa| grep mysql-server没有我们就开始安装&#xff0c;点击 这里&#xff0c;获取下载页面&#xff0c;按照图示选择合适的版本&#xff1a;第二步&#xff0c;进入/usr/local/soft/目录&#xff0c;在里面执行wget 下…

考公专业科目计算机,2017国考中国证监会专业科目考试大纲(计算机类)

一、考试目的考查考生是否具备证券期货监管工作所必需的计算机专业知识和相关知识的应用能力。二、考试内容与试卷结构考试形式为笔试&#xff0c;考试时间120分钟&#xff0c;满分100分。报考计算机类职位的考生参加本类别的专业科目考试。计算机类专业科目考试试题由以下两部…

qt 初学

1. qt4中没有setMainWidget函数&#xff0c;直接删除即可 2. 找不到QtNetWork头文件&#xff0c;在pro文件中增加 QT network 3. 打印QString qDebug() << QString对象 4. int 转 QString QString::number(int) 5. QStringList使用 QStringList wor…