LeetCode算法28:java 实现strStr()

本文探讨了strStr()函数的实现,旨在寻找一个字符串在另一个字符串中首次出现的位置。通过双层循环对比字符,文章提供了一个基础的解决方案,并附带示例代码。值得注意的是,当目标字符串为空时,应返回0,符合C语言strstr()及Java indexOf()的定义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题
实现 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);
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值