Algorithm之路二十八:Implement strStr()

题目:

写出一个类似于java中String.indexof()功能的函数,给出个字符串str,另一个字符串pattern,找出pattern在str中第一次出现的位置,找不到则返回-1

举例:

"hello"   "ll"   --->   2

"apple"  "pp"  --->  1

坑点:

这道题目无论使用什么样的语言都是很容易实现的,但是坑点在于,我们不知道oj的测试数据是什么,也不知道具体的要求,所以我天真的以为str="",pattern="",这样的应该返回-1,str="absa",str="",这样的,应该返回0,这就……比较坑了,难道这样的不应该返回-1吗,但是要说返回0,也没有什么问题。

代码:

#include <iostream>
#include <cstring>
#include <cstdlib>
using namespace std;
int strStr(string haystack, string needle)
{
	int haystack_length = haystack.length(),needle_length = needle.length();
	if(haystack_length < needle_length) return -1;
	if(needle_length == 0) return 0;
	int i = 0,j = 0,curr = 0;
	for(i = 0;i <= haystack_length - needle_length; i++)
	{
		curr = i;
		if(haystack[i] == needle[0])
		{
			for(j = 1;j < needle_length; j++)
				if(haystack[++curr] != needle[j]) break;
			if(j == needle_length)
				return i;
		}
	}
	if(i >= haystack_length - needle_length)
		return -1;
}
int main()
{
	string haystack = "a";
	string needle = "a";
	cout<<strStr(haystack, needle)<<endl;
	return 0;
}

时间复杂度:

时间复杂度是由str和pattern的相匹配程度决定的,这是要考虑二者之间的相似程度,二者的相似程度决定了嵌套循环中内部循环的次数。假如说,在str中所有长度为pattern.length()的子字符串中与pattern具有的公共字串(从字符串头部开始)的平均长度为m,(以上听起来比较绕,去看一下代码就很容易明白了),那么最坏情况下的时间复杂度为O((str.length()-pattern.length())m)。

空间复杂度:

O(1)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值