为什么会这样

炸地球 2020-09-16 10:02:57
#define _CRT_SECURE_NO_WARNINGS //关闭安全
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void tihu(char** ppstr, char* old, char* new)
{
int pplen = strlen(*ppstr);//原字符串长度
int olen = strlen(old);//被替换的长度
int nlen = strlen(new);//替换的长度

char* p1 = *ppstr; //创建2个指针保存原字符串的地址
char* p2 = *ppstr;

while (*p1 != '\0')//循环
{
*p1 = *p2;// 2指针错位

int flag = 1; //假设找到 1

for (int i = 0; i < olen; i++)
{
if (p2[i] != old[i] || p2[i] == '\0')//寻找
{
flag = 0;//找不到
break;//跳出
}
}

if (flag == 0)
{
p1++;
p2++;
}
else
{
int n = p1 - *ppstr;//确认位置
int m = p2 - *ppstr;

*ppstr = _recalloc(*ppstr, pplen + nlen - olen + 1, 1);//扩展内存+1处理'\0'

p1 = *ppstr + n;//找回位置
p2 = *ppstr + m;

for (char* p = p2 + strlen(p2); p >= p2; p--)//移动字符串
{
*(p + nlen - olen) = *p;
}

for (int i = 0; i < nlen; i++)//拷贝
{
p2[i] = new[i];
}

}



}

}

void main()
{
int slen = strlen("aaaaaaaa like aaaaa like aaaaaaaa"); //原字符串长度
char* p = malloc(slen + 1);// 分配内存空间

strcpy(p, "aaaaaaaa CCCC aaaaa CCCC aaaaaaaa");//拷贝字符串
tihu(&p, "CCCC", "bbbb bbbb bbbb bbbb");//替换


printf("%s", p);


system("pause");
}

...全文
202 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
真相重于对错 2020-09-17
  • 打赏
  • 举报
回复
你的代码有逻辑问题, *ppstr = _recalloc(*ppstr, pplen + nlen - olen + 1, 1); 因为。如果有两处要替换,且新字符串大于旧字符串 当你替换了第一个以后,这个pplen也要随之改变,否则recalloc后的字符串将放不下,新字符串
自信男孩 2020-09-17
  • 打赏
  • 举报
回复
//#define  _CRT_SECURE_NO_WARNINGS //关闭安全
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#if 0
void tihu(char** ppstr, char* old, char* new_str)
{
int pplen = strlen(*ppstr);//原字符串长度
int olen = strlen(old);//被替换的长度
int nlen = strlen(new_str);//替换的长度

char* p1 = *ppstr; //创建2个指针保存原字符串的地址
char* p2 = *ppstr;

while (*p1 != '\0')//循环
{
*p1 = *p2;// 2指针错位

int flag = 1; //假设找到 1

for (int i = 0; i < olen; i++)
{
if (p2[i] != old[i] || p2[i] == '\0')//寻找
{
flag = 0;//找不到
break;//跳出
}
}

if (flag == 0)
{
p1++;
p2++;
}
else
{
int n = p1 - *ppstr;//确认位置
int m = p2 - *ppstr;

*ppstr = recalloc(*ppstr, pplen + nlen - olen + 1, 1);//扩展内存+1处理'\0'

p1 = *ppstr + n;//找回位置
p2 = *ppstr + m;

for (char* p = p2 + strlen(p2); p >= p2; p--)//移动字符串
{
*(p + nlen - olen) = *p;
}

for (int i = 0; i < nlen; i++)//拷贝
{
p2[i] = new_str[i];
}

}
}

}
#endif

void replace_str(char **str, const char *substr, const char *newstr)
{
int i;
int src_len = strlen(*str);
int sub_len = strlen(substr);
int new_len = strlen(newstr);
char *pstr = *str;
unsigned int len, pos;

len = src_len;
while (*pstr) {

for (i = 0; i < sub_len; i++) {
if (*pstr && pstr[i] != substr[i])
break;
}
if (src_len - (pstr-*str) < sub_len)
break;

if (i >= sub_len) {
pos = pstr - *str;
//if (sub_len < new_len) {
*str = (char *)realloc(*str, src_len + new_len - sub_len + 1);
if (!(*str))
return;
pstr = *str + pos;
memmove(pstr + new_len, pstr+sub_len, src_len - pos);
src_len = src_len + new_len - sub_len;
memcpy(pstr, newstr, new_len);
pstr += new_len;
//}
continue;
}
pstr++;
}
(*str)[src_len] = 0;
}


//void main()
int main()
{
int slen = strlen("aaaaaaaa like aaaaa like aaaaaaaa"); //原字符串长度
char *p = (char *)malloc(slen + 1);// 分配内存空间

strcpy(p, "aaaaaaaa CCCC aaaaa CCCC aaaaaaaa");//拷贝字符串
//tihu(&p, "CCCC", "bbbb bbbb bbbb bbbb");//替换
printf("Before replace: %s\n", p);
replace_str(&p, "CCCC", "bbbb bbbb bbbb bbbb");
//replace_str(&p, "CCCC", "abc");


printf("%s\n", p);



//system("pause");
//
return 0;
}

供参考~

linux下编译测试~realloc可能不一样,可以参考一下~

69,371

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧