版权声明:可以转载,请注明链接出处 https://blog.csdn.net/xihuanyuye/article/details/85234943
问题
实现 strStr() 函数。
给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。
示例 1:
输入: haystack = “hello”, needle = “ll”
输出: 2
示例 2:
输入: haystack = “aaaaa”, needle = “bba”
输出: -1
说明:
当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。
对于本题而言,当 needle 是空字符串时我们应当返回 0 。这与C语言的 strstr() 以及 Java的 indexOf() 定义相符。
思考
或许是个人思路不对,感觉这道题不应该定位成简单题目。最后也只想到了采用循环的思路,结果发现计算时长算是比较长的。或许该问题有更好的解决思路,待后续具体测试。
代码
public class _28ImplementstrStr{
public int strStr(String haystack, String needle){
if(needle.length()==0) return 0;
for(int i =0;i< haystack.length();i++){
int m = 0;
for(int j=0;j<needle.length();j++){
if((m+i)== haystack.length()) break;
if(haystack.charAt(m+i)==needle.charAt(j)){
m++;
if(j==(needle.length()-1)) return i;
}else{
break;
}
}
}
return -1;
}
public static void main(String[] arg){
_28ImplementstrStr ImplementstrStr = new _28ImplementstrStr();
String haystack = "hello";
String needle = "ll";
int point = ImplementstrStr.strStr(haystack,needle);
System.out.println(point);
}
}