isSubstring子串判断笔试题
来源:互联网 发布:魔兽数据库 编辑:程序博客网 时间:2024/05/22 08:27
出处:http://hawstein.com/posts/1.8.html
声明:本文采用以下协议进行授权: 自由转载-非商用-非衍生-保持署名|Creative Commons BY-NC-ND 3.0 ,转载请注明作者及出处。
题目
原文:
Assume you have a method isSubstring which checks if one word is a substring of another. Given two strings, s1 and s2, write code to check if s2 is a rotation of s1 using only one call to isSubstring ( i.e., “waterbottle” is a rotation of “erbottlewat”).
译文:
假设你有一个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 = waterbottlewaterbottle
很容易可以发现,s1+s1其实是把s1中每个字符都旋转了一遍,而同时保持原字符不动。 比如waterbottle向右旋转2个字条应该是:terbottlewa,但如果同时保持原字符不动, 我们得到的就是waterbottlewa,而terbottlewa一定是waterbottlewa的子串, 因为waterbottlewa只是在terbottlewa的基础上再加上一条原字符不动的限制。 因此s1+s1将包含s1的所有旋转字符串,如果s2是s1+s1的子串,自然也就是s1 的旋转字符串了。
代码如下:
#include <iostream>#include <string>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; //cout<<string::npos<<endl; return 0;}
- isSubstring子串判断笔试题
- Arrays_Strings 利用isSubstring检查是否子串 @CareerCup
- 《CTCI》1.8 调用一次isSubstring判断旋转字符串
- 网易内推笔试编程题-字符串子序列判断
- 程序员笔试题---【最大回文子串】
- 华为2014校园招聘笔试,围棋吃子判断
- 笔试算法-最长子串
- 字符串判断子串
- 判断子串
- 子串判断
- 判断子串
- 例题:判断子串
- 谷歌笔试题(最长公共子串)
- 经典笔试题 最长公共子串(连续)问题
- 最长公共子串 | 阿里2015笔试附加题2
- 字符串子串(网易2017春招笔试题)
- 【面试笔试算法】Problem 9: 腾讯2016年研发实习笔试题:最长回文子串
- 名企笔试:字符串子串(网易2017春招笔试题)
- MySQL-index
- 编写一个C程序,用于打印九九乘法表
- [POJ2104]K-th Number
- 大型网站图片服务器架构的演进
- [转]PHP ob_start() and ob_start('ob_gzhandler')
- isSubstring子串判断笔试题
- 一个社交App需实现的功能
- 随机字符串
- eclipse安装svn插件报eclipse subversion native library not available
- 关于classpath
- [POJ3264]Balanced Lineup
- [LeetCode]Power of Two
- 车载软件未来趋势
- 怎样实现花生壳开服