LeetCode算法28:java 实现strStr()

版权声明:可以转载,请注明链接出处 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);
	}
}

猜你喜欢

转载自blog.csdn.net/xihuanyuye/article/details/85234943
今日推荐