C语言 在字符串s1中,查找字符串a,将其替换成字符串b

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++  这个很容易忘,忘了的话程序会一直跑 比较容易发现,一般程序跑飞 都是漏了这些
}

 

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值