字符串处理1 - strip str2 from str1 and link the rest

来源:互联网 发布:mpp打开软件 编辑:程序博客网 时间:2024/05/16 17:42

有两个字符串,str1, str2, 扣掉str1中的str2---------------------->>

-------------------------------------------------------------------------------->>

在最后要粘贴后面字符串时,由于忘记申请dest[100],造成segmentation fault。申请的指针是不能用于strcat的

findStr其实和strstr一样的,只不过返回了一个offset

从这篇开始,我后面要将左右的字符串操作的函数自己写一遍,并做到熟练。

char* p; p字符串的最后一个是'\0', 所以strlen检查'\0'.array没有,要手动自己加上,否则打印字符串时,会碰上问题。

#include<stdio.h>//func as strstr, return the offset of the first matchint findStr(const char *src, const char *dest){    char* tmp = src;    int i;    while(*src)    {        for (i=0; *(src+i) == *(dest+i); i++){              if (!*(dest+i+1))              return (src-tmp);        }        src++;    }    return -1;}void main(void){    char* str = "helloworldhello2hello3";    char* str1 = "world";    int num = findStr(str,str1);    int len = strlen(str1);    char dest[100];    strncpy(dest, str, num);    strcpy(dest+num, str+num+len);    printf("%s",dest);}

补,strstr1功能和findStr一样,貌似更简单些,其实递归一点不省效率。

char* strstr1(char* str1, const char* str2){    char* tmp1= str1;    char* tmp2 = str2;    while(*tmp1 && (*tmp1 == *tmp2))    {       tmp1++;       tmp2++;    }    if(!*tmp2)        return tmp1;    str1++;    strstr1(str1,str2);}


原创粉丝点击