题目:
写出一个类似于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)。