利用已知函数判断字符串是否为另一字符串的子串
来源:互联网 发布:小班防火知多少ppt 编辑:程序博客网 时间:2024/05/16 08:11
题目
假设你有一个isSubstring函数,可以检测一个字符串是否是另一个字符串的子串。 给出字符串s1和s2,只使用一次isSubstring就能判断s2是否是s1的旋转字符串, 请写出代码。旋转字符串:”waterbottle”是”erbottlewat”的旋转字符串。
解答
题目说我们使用一次isSubstring函数就可以判断s2是否是s1的旋转字符串, 如果从原始字符串s1和s2直接入手肯定不行,因为它们根本不存在子串关系。 如果不断地旋转字符,然后调用isSubstring,又需要调用多次的isSubstring。 而且通过旋转字符再判断,可以直接用等号判断,根本用不上isSubstring。
既然如此,我们就要考虑去改变原始字符串。要判断a串是否是b串的子串, 一般情况下都会有b串长度大于a串,长度相等的话就直接判断它们是不是相等的串了。 我们可以考虑把串s1变长,然后调用一次isSubstring判断s2是否是s1变长后的子串, 如果是,就得出s2是s1的旋转字符串。s1怎么变长呢?无非就是s1+s1或是s1+s2, s2一定是s1+s2的子串,因此这样做没有任何意义。而s1+s1呢? 我们就上面的例子进行讨论:s1=waterbottle,s2=erbottlewat. 则:
很容易可以发现,s1+s1其实是把s1中每个字符都旋转了一遍,而同时保持原字符不动。 比如waterbottle向右旋转2个字条应该是:terbottlewa,但如果同时保持原字符不动, 我们得到的就是waterbottlewa,而terbottlewa一定是waterbottlewa的子串, 因为waterbottlewa只是在terbottlewa的基础上再加上一条原字符不动的限制。 因此s1+s1将包含s1的所有旋转字符串,如果s2是s1+s1的子串,自然也就是s1 的旋转字符串了。
代码如下:
#include <iostream>#include <cstring>#include <cstdio>#include <cstdlib>using namespace std;bool isSubString(string s1, string s2){if (s1.find(s2) != string::npos) return true;else return false;}bool isRotation(string s1, string s2){if (s1.length() != s2.length() || s1.length() <= 0)return false;return isSubString(s1 + s1, s2);}int main(){string s1 = "apple";string s2 = "pleap";cout << isRotation(s1, s2) << endl;return 0;}
- 利用已知函数判断字符串是否为另一字符串的子串
- 利用已知函数判断字符串是否为另一字符串的子串
- 利用已知函数判断字符串是否为另一字符串的子串
- 1.8 利用已知函数判断字符串是否为另一字符串的子串
- 【原创】演示判断一个字符串是否为另一字符串的子串的函数的汇编源程序
- python判断一个字符串是否为另一字符串的子串的几种方法
- poj1936判断一个字符串是否为另一字符串的子串
- [LeetCode]392. Is Subsequence 判断字符串是否为另一字符串的子串
- 判断一个字符串是否为另一个字符串的子串
- 以和为标准的判断某字符串为另一字符串子串的方法
- js中判断字符串中是否包含另一子字符串
- 判断字符串是否为数字&&判断字符串是否为字母&&判断子字符串是否为汉字
- 判断一个字符串是否为另外一个字符串的子串
- Java判断字符串是否包含的另一字符串的方法
- 判断字符串是否包含另一字符串的全排列
- javascript判断是否为子字符串
- 判断一个字符串是否为另一个字符串的旋转后的子字符串
- 利用顺序栈判断一个字符串是否为对称串
- 有关aop
- 用DNAT实现外网访问内网web服务
- LoadRunner 负载测试使用小记
- Samba的安装配置和使用 -- unbuntu
- SSL协议流程
- 利用已知函数判断字符串是否为另一字符串的子串
- 待深入了解的技术记录
- web前端控制
- [gcc] gcc编译时不提示警告信息
- html5游戏源码之《三国杀版连连看》canvas游戏源码下载分享
- 关于Hibernate中fetch作用描述
- hdu 1011 Starship Troopers(树形DP)
- jquery form 表单验证
- 排序算法的基本思想