标题:大家发表一下意见,这个程序怎么写啊.
只看楼主
jackeyhlj
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:51
专家分:0
注 册:2007-3-27
 问题点数:0 回复次数:6 
大家发表一下意见,这个程序怎么写啊.

将主字符串s中出现的子串t全部替换为子串r
相关提示:
(1) 在主串s中查找子串t;
(2) 找到后分三种情况讨论进行替换:源子串长度小于替换后的子串长度;源子串长度大于替换后的子串长度;源子串长度等于替换后的子串长度;
最好是用C++写的

搜索更多相关主题的帖子: 意见 
2007-04-29 16:12
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
得分:0 
KMP.模式匹配.
定义局部变量字符指针保存源串中的后一部分,然后进行字符串连接和复制操作.

倚天照海花无数,流水高山心自知。
2007-04-29 19:50
jackeyhlj
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:51
专家分:0
注 册:2007-3-27
得分:0 

我有一个地方还不清楚,就是如何在主串中寻找子串的位置,并保存.


2007-04-29 21:12
xhjerry
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2007-4-28
得分:0 
模式匹配问题,首先得保证主字符串中不出现子串重叠问题(如:在abcabcabd中找abcab),否则该问题便有二义性。在这个前提下,用字符数组实现比较简单。
字符数组的末尾都添加了'\0'字符,以下是c代码:
int stringconvet(char s[],char t[],char r[])
{
int mainlen=strlen(s),sublen=strlen(t);
int memory[M];//M足够大
int i=0,times=0;
while(s[i])//搜索整个主字符串直至遇到'\0'
{
int j=0;
while(j<m&&t[j]==s[i+j])
{
j++;
if(j==sublen) memory[times++]=i;//保存子串的第一个字符在主串中出现的位置
}
i++;
}
if(times==0)
return 0;//主串中没有对应的子串
//下面实现替换操作
int convertlen=strlen(r);
int interval=convertlen-sublen;//子串和替换串的长度差


for(i=0;i<times;i++)
{
j=i;
int pos=memory[i];
//move函数实现主串中子串位置后的字符串的移动,起到保护原串的作用,interval的正负决定移动方向,大小决定移动位数,interval=0时不移动。
//该函数不是很难,自己实现吧。
move(pos+m,interval);
if(j<times)
memory[++j]+=interval;
for(int m=0;m<convertlen;m++)
{
s[pos++]=r[m];
}
}

return times;//子串在主串中出现的次数
}
2007-04-30 14:35
I喜欢c
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:64
帖 子:1749
专家分:0
注 册:2007-3-2
得分:0 
http://bbs.bc-cn.net/viewthread.php?tid=130204&star=at#

曾发表的一篇文章..
希望对你有帮助~``

 我是指针,却丢失了目标地址!          我是循环,却缺少了结束条件!      我是函数,却没有人来调用!   
2007-04-30 22:39
jackeyhlj
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:51
专家分:0
注 册:2007-3-27
得分:0 

谢谢大家的宝贵的意见,我会仔细考虑的,


2007-05-01 00:03
jackeyhlj
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:51
专家分:0
注 册:2007-3-27
得分:0 
还是有点不懂啊,能给出完整的程序吗?

2007-05-02 21:12



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-135997-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.195558 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved