w847815594
酒笙清芷
2020-08-19 23:03
采纳率: 0%
浏览 82

C语言,字符串替换,请求大佬支援。

字符串替换。在主串S中查找子串T,将所有的T都替换成字符串R。

【思路指导】
(1)参考上题,借用strncmp来查找要被替换的子串T:对于不是子串T的部分,复制到新的串中(然后,下标增1),而对于是子串的部分,则将字符串R复制到新串中,(同时,下标增strlen(T))
(2)在新字符串的末尾添加’\0’

搞不出来 请求大佬支援。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • caozhy
    void str_str_replace(char s1[],char a[],char b[])  //字符串s1中的a 替换成b
    {
        int s1_len=strlen(s1);  //计算三者长度
        int a_len=strlen(a);
        int b_len=strlen(b);
    
        //找出a[]
        int i=0; //i用来指定s1下标
        int j=0;//j指定要被替换的
        int flag=0;
    
        while(s1[i])   //在s1[]中 找a[],每次找一个元素 并且flag++,没找到就把flag清零,最后找到的话 flag是=a_len的
        {
            if(s1[i] == a[j])  //匹配s1[x] a[0]成功
            {   flag++;  //注意每次匹配成功flag都会+1
                i++;
                j++;
                while(s1[i] == a[j])
                {
                    flag++;
                    i++;
                    j++;
                }
    
            }
            else
                flag = 0 ;
    
            if(flag == a_len)  //若标志位=a的长度,匹配成功  先把s1从位置i-a_len开始,后移b_len个单位, 然后插入b
            {
                int js=0; //js(计数)  用来计数当前移动的次数 一共要移动b_len次
                for(int a=i-a_len ; a<i-a_len+b_len ; a++) //s1[]从i-alen开始,要后移b_len个单位
                {
                    s1[s1_len + b_len - js] = s1[s1_len-js];
                }
    
                s1[s1_len + b_len +1]='\0';    //结个尾  给个\0
    
                for(js=0;js<b_len ; js++)     //将b插入到指定位置
                    s1[i-a_len + js] = b[js];
            }
    
            i++;
        } //这个括号是整个whilew循环的,上面需要i++  这个很容易忘,忘了的话程序会一直跑 比较容易发现,一般程序跑飞 都是漏了这些
    }
    
    

    https://blog.csdn.net/weixin_39380125/article/details/105081763

    点赞 评论

相关推荐