[C语言]详细讲解如何模拟实现strstr

首先给出代码,详细图文讲解见代码下方
#include <stdio.h>
#include <stdlib.h>
char* my_strstr(const char* dest, const char* str)
{
const char *pdest = dest;//pdest为标记目标字符串的首位
char *s1, s2;//s1,s2分别为目标字符串和寻找字符串的流动寻找指针
if (!(str))
{
return (char
)dest;
}
while (pdest)
{
s1 = (char
)pdest;
s2 = (char
)str;
while ((*s1!=’\0’) && (*s2!=’\0’) && (*s1 == s2))//当两个流动寻找指针没有到结尾且
//相等时,继续向后一位寻找
{
s1++;
s2++;
}
if (s2 == ‘\0’)//当寻找字符串到结尾了则表示子串找到,返回pdest位置
{
return (char
)pdest;
}
pdest++;//若只是前几位相等但不是子串时,将目标字符串指针继续向后移动查找
}
return NULL;
}
int main()
{
char
ret = my_strstr(“student”, “dent”);
if (ret != NULL)
{
printf("%s", ret);
}
else
{
printf(“false”);
}
system(“pause”);
return 0;
}

[C语言]详细讲解如何模拟实现strstr