模拟实现strstr库函数,函数的功能是在一个字符串中查找子字符串,找到了返回第一次出现的地址,不存在则返回NULL.

解:程序:

#include<stdio.h>

#include<string.h>

 

char *my_strstr(char const *destchar 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

请按任意键继续. . .