C++中strstr函数的实现方法总结
函数说明:
包含文件:string.h
函数名: strstr
函数原型:extern char *strstr(char *str1, char *str2);
功能:从字符串str1中查找是否有字符串str2, 如果有,从str1中的str2位置起,返回str1的指针,如果没有,返回null。
返回值:返回该位置的指针,如找不到,返回空指针。
方法一:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
#include <iostream>
#include <assert.h>
using namespace std;
char * My_strstr( char *src, char *substr)
{
assert (src != NULL && substr != NULL);
unsigned int size = strlen (src);
for ( int i = 0; i < size; ++i,++src)
{
char *p = src;
for ( char *q = substr;;p++,q++)
{
if (*q == '\0' ) //在src中找到连续的substr子串停止并返回
{
return src;
}
if (*q != *p)
{
break ;
}
}
}
return NULL;
}
int main()
{
char *res = My_strstr( "abcdefg" , "cde" );
if (res != NULL)
{
cout<< "exist:" <<res<<endl;
}
else
{
cout<< "no exist!" <<endl;
}
return 0;
}
|
方法二:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
#include <iostream>
#include <assert.h>
using namespace std;
char * My_strstr( const char * s1, const char * s2)
{
int n;
if (*s2)
{
while (*s1)
{
for (n=0;*(s1+n)==*(s2+n);n++)
{
if (!*(s2+n+1))
return ( char *)s1;
}
s1++;
}
return NULL;
}
else
return ( char *)s1;
}
int main()
{
char *res = My_strstr( "abcdefg" , "cde" );
if (res != NULL)
{
cout<< "exist:" <<res<<endl;
}
else
{
cout<< "no exist!" <<endl;
}
return 0;
}
|
方法三:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#include <iostream>
#include <assert.h>
using namespace std;
char * My_strstr( const char * s1, const char * s2)
{
const char *p=s1;
const size_t len= strlen (s2);
for (;(p= strchr (p,*s2))!=0;p++) // strchr查找字符串s中首次出现字符c的位置
{
if ( strncmp (p,s2,len)==0)
{
return ( char *)p;
}
}
return (0);
}
int main()
{
char *res = My_strstr( "abcdefg" , "cde" );
if (res != NULL)
{
cout<< "exist:" <<res<<endl;
}
else
{
cout<< "no exist!" <<endl;
}
return 0;
}
|
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/baoge_leopard/article/details/39779959