模拟实现strstr库函数,函数的功能是在一个字符串中查找子字符串,找到了返回第一次出现的地址,不存在则返回NULL.
解:程序:
#include<stdio.h>
#include<string.h>
char *my_strstr(char const *dest, char const *src)
{
char *pdest = (char*)dest;
char *psrc = (char*)src;
int i = 0, j = 0, k = 0, m, n;
while (i < strlen(dest) && j < strlen(src))
{
if (*(pdest + i) == *(psrc + j))
{
i++;
j++;
}
else
{
j = 0;
k++;
i = k;//k用来记录原来i的位置
}
}
if (j >= strlen(src)) //判断找到子字符串的条件
{
printf("找到子字符串:%s\n",src);
return *(pdest+i);
}
else
{
printf("没有找到子字符串:%s\n", src);
return NULL;
}
}
int main()
{
char arr1[] = "ABCDEFGABCDH";
/*char arr2[] = "FGABCD";*/
char arr2[] = "FGBCD";
char *c;
c = my_strstr(&arr1,&arr2);
return 0;
}
结果1:
找到子字符串:FGABCD
请按任意键继续. . .
结果2:
没有找到子字符串:FGBCD
请按任意键继续. . .