数据结构上机作业1-5章(8)
4.17③ 编写算法,实现串的基本操作Replace(&S,T,V)。要求采用教科书4.2.1节中所定义的定长顺序存储表示,但不允许调用串的基本操作。 要求实现以下函数:
Status Replace(SString& s, SString t, SString v);
/* 用串v替换串s中所有和串t匹配的子串。 */ /* 若有与t匹配的子串被替换,则返回TRUE;*/ /* 否则返回FALSE */ 定长顺序串SString的类型定义:
typedef unsigned char SString[MAXSTRLEN+1]; /* s[0] is the string's length */
int Index(SString s, SString t,int pos ) {
int i = pos; int j = 1;
while( i<= s[0]&&j<=t[0]) {
if( s[i] == t[j] ){ ++i; ++j; } else{i= i-j+2;j=1;} }
if( j > t[0] ) return i - t[0]; else return 0; }
Status Replace(SString& s, SString t, SString v)/* 用串v替换串s中所有和串t匹配的子串。 */ /* 若有与t匹配的子串被替换,则返回TRUE;*/ /* 否则返回FALSE */ { int flag = 0;//是否替换的标志
int i,j,w,r; //i是s1的标志,j是s的标志, SString s1;
for( i = 0; i <= s[0]; i++ ) s1[i] = s[i];
for( i = 1, j = 1; i <= s1[0]; ) {
w = Index( s1, t, i); //返回t的起始位置 if( !w ) {
while( i <= s1[0] )
s[j++] = s1[i++]; } else {
while( i < w )
s[j++] = s1[i++]; for( r = 1; r <= v[0]; r++ ) s[j++] = v[r]; flag++; i += t[0]; } }
s[0] = --j;
if( flag ) return TRUE; return FALSE; }
/*int i,j,k,l;
for(i=1;i<=s[0]-t[0]+1;i++) {
for(j=i,k=1;t[k]&&s[j]==t[k];j++,k++) if(k>t[0]) {
if(t[0]==v[0])
for(l=1;i<=t[0];l++) s[i+l-1]=v[l]; else if(t[0] for(l=s[0];l>i+t[0];l--) s[l+v[0]-t[0]]=s[l]; for(l=1;l<=v[0];l++) s[i+l-1]=v[l]; } else { for(l=i+v[0];l<=s[0]+v[0]-t[0];l++) s[l]=s[l-v[0]+t[0]]; for(l=1;l<=v[0];l++) s[i+l-1]=v[l]; } s[0]=s[0]-t[0]+v[0]; i=i+v[0]; } } return TRUE; */ 4.20③ 编写算法,从串s中删除所有和串t相同的子串。 要求实现以下函数: Status DelSub(SString &s, SString t); /* 从串s中删除所有和串t匹配的子串。 */ /* 若有与t匹配的子串被删除,则返回TRUE;*/ /* 否则返回FALSE */ 定长顺序串SString的类型定义: typedef unsigned char SString[MAXSTRLEN+1]; /* s[0] is the string's length */ int Index(SString s, SString t,int pos ) { int i = pos; int j = 1; while( i<= s[0]&&j<=t[0]) { if( s[i] == t[j] ){ ++i; ++j; } else{i= i-j+2;j=1;} } if( j > t[0] ) return i - t[0]; else return 0; } Status DelSub(SString &s, SString t) /* 从串s中删除所有和串t匹配的子串。 */ /* 若有与t匹配的子串被删除,则返回TRUE;*/ /* 否则返回FALSE */ { int flag = 0;//是否替换的标志 int i,j,w; //i是s1的标志,j是s的标志, for( i = 1, j = 1; i <= s[0]; ) { w = Index( s, t, i); //返回t的起始位置 if( !w ) { while( i <= s[0] ) s[j++] = s[i++]; } else { while( i < w ) s[j++] = s[i++]; flag++; i += t[0]; } } s[0] = --j; if( flag ) return TRUE; return FALSE; } 4.24③ 采用教科书4.2.2节中所定义的堆分配存储表示。试写一算法,在串的堆存储结构上实现串基本操作Concat(&T, s1, s2)。 要求实现以下函数: Status Concat(HString &S, HString S1, HString S2) /* 用S返回由S1和S2联接而成的新串 */ 堆串HString的类型定义: typedef struct { char *ch; // 若是非空串,则按串长分配存储区,否则ch为NULL int length; // 串长度 } HString; Status Concat(HString &S, HString S1, HString S2) /* 用S返回由S1和S2联接而成的新串 */ { int i, j; if( !(S.ch=(char*)realloc(S.ch,(S1.length+S2.length)*sizeof(char)))) exit(OVERFLOW); for(i=0;i S.length=S1.length+S2.length; } 4.30⑤ 假设以定长顺序存储结构表示串,试设计一个算法,求串s中出现的第一个最长重复子串及其位置,并分析你的算法的时间复杂度。 要求实现以下函数: void CommonStr(SString s, SString &sub, int &loc); /* 求串s中出现的第一个最长重复子串sub及其位置loc */ 定长顺序串SString的类型定义: typedef unsigned char SString[MAXSTRLEN+1]; /* s[0] is the string's length */ void CommonStr(SString s, SString &sub, int &loc) /* 求串s中出现的第一个最长重复子串sub及其位置loc */ { int index=0,length=0,length1,i=0,j,k; while(i j=i+1;
相关推荐:
- [基础教育]2016-2022年中国钢芯铝绞线市场现状调
- [基础教育]语文部编版初一语文下册练习题 句式变
- [基础教育]南京继续教育参考答案--深入学习贯彻习
- [基础教育]国旗下讲话稿——珍惜时间好读书
- [基础教育]北师大版六年级数学下册圆锥的体积教学
- [基础教育]人教版-音乐-四年级下册-四年级下册音
- [基础教育]乔布斯2019年斯坦福大学毕业典礼致辞.d
- [基础教育]2015年加油站安全知识竞赛试题及答案
- [基础教育]2020年教师年度考核个人工作总结
- [基础教育]2019年中考历史试题-2019年大庆市初中
- [基础教育]初三仁爱英语第一轮总复习教案
- [基础教育]SG-A094电气配管安装工程隐蔽验收记录
- [基础教育]冀教版小学数学三年级下册第六单元教材
- [基础教育]青岛版(五制)小学科学二年级下册16《制
- [基础教育]2018-2019年初中科学初一中考真卷测试
- [基础教育]幼儿园大班期末简短评语精选
- [基础教育]2018云南临沧公务员考试申论技巧:这样
- [基础教育]学校食堂经营管理方案
- [基础教育]新中国砥砺奋进的七十年原文
- [基础教育]真空泵的选型及常用计算公式
- 高职田径课程教学现状与对策
- 全髋关节置换术在老年股骨颈骨折患者中
- 青人社厅函〔2016〕576号(附件)工资
- cp101-07砂子检验作业指导书 - secret
- 微观经济学 第八章 博弈论 习题
- 2014高考真题(词语运用)汇编及答案
- 2018年人教版七年级语文下册《第三单元
- 苏教版数学四年级上册第一单元试题 - M
- 四川大学新闻与传播考研2000-2010年真
- 浙江万里学院英语专业四年制本科教学计
- 最新2018马年事业祝福语-范文word版(2
- 最全模具行业术语英文翻译
- 皮亚杰的发展心理学理论
- 64篇高考情景式默写 练习题及答案
- 仿写(学生稿)
- 《SQL Server数据库技术》试卷A
- 第七章作业答案
- 江苏省赣榆县海头高级中学高中语文必修
- 浙江省2001年10月自考正常人体解剖学答
- 2012英语重点短语




