数据库中的链串问题

hukaibao2007 2008-04-11 05:48:09
以链串为存储结构,设计一个算法把最先出现的子串“ab”改为“xyz”
void Repl(LiString *&s)
{
LiString *p=s->next,*q;
int find=0;
while(p->next!=NULL&&find==0)
{
if(p->data=='a'&&p->next->data=='b')
{ p->data='x';p->next->data='z';
q=(LiString *)malloc(sizeof(LiString));
q->data='y';q->next=p->next;p->next=q;
find=1;
}
else p=p->next;
}
}
现设计一个算法,把第二个出现的子串"ab"替换为"xyz"
请教一下,应该怎么设计?
...全文
91 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
jiaping99 2008-04-11
  • 打赏
  • 举报
回复
二楼的不错哦~~
jieao111 2008-04-11
  • 打赏
  • 举报
回复
结帖把。。^_^
hukaibao2007 2008-04-11
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 hukaibao2007 的回复:]
[/Quote]
hukaibao2007 2008-04-11
  • 打赏
  • 举报
回复
明白了,谢谢!
jieao111 2008-04-11
  • 打赏
  • 举报
回复
int m=0;
while(p->next!=NULL&&find==0)
{
if(p->data=='a'&&p->next->data=='b'&&m++!=0)
{ p->data='x';p->next->data='z';
q=(LiString *)malloc(sizeof(LiString));
q->data='y';q->next=p->next;p->next=q;
find=1;
}
else p=p->next;
}
}
jieao111 2008-04-11
  • 打赏
  • 举报
回复
弄个累加器把 ,或者弄个标志也行
int m=0;
while(p->next!=NULL&&find==0)
{
if(p->data=='a'&&p->next->data=='b'&&m++!=0)
{ p->data='x';p->next->data='z';
q=(LiString *)malloc(sizeof(LiString));
q->data='y';q->next=p->next;p->next=q;
find=1;
}
else p=p->next;
}
}

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

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