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

 

可以使用C语言字符串处理函数strstr()和strncpy()来实现字符串替换操作。具体步骤如下: 1. 定义三个字符串S1、S2和S3,分别表示原字符串、被替换的字符串和替换后的字符串。 2. 使用strstr()函数S1查找S2字符串,如果找到了则返回S2字符串S1的首个字符的地址。 3. 如果找到了S2字符串,则使用strncpy()函数将S3字符串复制到S1S2字符串的位置上,并将S2字符串后面的字符串向后移动。 4. 重复步骤2和步骤3,直到S1不再存在S2字符串为止。 5. 最后得到的S1字符串就是替换后的字符串。 下面是一段C语言代码示例,用于将字符串S1所有字符串S2替换为字符串S3: ``` #include <stdio.h> #include <string.h> void replace(char *s1, const char *s2, const char *s3) { char *p = NULL; int len1 = strlen(s1); int len2 = strlen(s2); int len3 = strlen(s3); int len4 = len1 + (len3 - len2) * len1 / len2; char *tmp = (char*)malloc(len4 + 1); memset(tmp, 0, len4 + 1); p = strstr(s1, s2); while(p != NULL) { strncpy(tmp + strlen(tmp), s1, p - s1); strcat(tmp, s3); s1 = p + len2; p = strstr(s1, s2); } strcat(tmp, s1); strcpy(s1, tmp); free(tmp); } int main() { char s1[] = "Hello, World! This is a test string."; char s2[] = "test"; char s3[] = "example"; printf("Before replace: %s\n", s1); replace(s1, s2, s3); printf("After replace: %s\n", s1); return 0; } ``` 输出结果为: ``` Before replace: Hello, World! This is a test string. After replace: Hello, World! This is a example string. ``` 注:上述代码使用了动态内存分配函数malloc()和free(),需要在使用完内存后记得释放。为了防止替换后字符串超过原字符串长度的情况,根据替换后字符串长度估算了最终字符串长度,并在堆上分配了足够的内存。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值