字符串替换。在主串S中查找子串T,将所有的T都替换成字符串R。
【思路指导】
(1)参考上题,借用strncmp来查找要被替换的子串T:对于不是子串T的部分,复制到新的串中(然后,下标增1),而对于是子串的部分,则将字符串R复制到新串中,(同时,下标增strlen(T))
(2)在新字符串的末尾添加’\0’
搞不出来 请求大佬支援。
字符串替换。在主串S中查找子串T,将所有的T都替换成字符串R。
【思路指导】
(1)参考上题,借用strncmp来查找要被替换的子串T:对于不是子串T的部分,复制到新的串中(然后,下标增1),而对于是子串的部分,则将字符串R复制到新串中,(同时,下标增strlen(T))
(2)在新字符串的末尾添加’\0’
搞不出来 请求大佬支援。
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