




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据结构实验报告课程 数据结构 _ 实验名称 顺序串基本操作 院系 电信学院 专业班级 计科10-4 姓名 学 号 一、实验目的1)熟悉串的定义和串的基本操作。2)掌握顺序串的基本运算。3)加深对串数据结构的理解,逐步培养解决实际问题的编程能力。二、实验环境装有Visual C6.0的计算机。本次实验共计2学时。三、实验内容编写一个程序,实现顺序串的各种基本运算,并在此基础上设计一个主程序。具体如下:编写串的基本操作函数顺序串类型定义如下所示:typedef struct char chMAX; int length; SeqString;(1)串赋值 Assign(s,t) 将一个字符串常量赋给串s,即生成一个其值等于t的串s(2)串复制 StrCopy(s,t) 将串t赋给串s(3) 计算串长度 StrLength(s) 返回串s中字符个数(4)判断串相等StrEqual(s,t) 若两个串s与t相等则返回1;否则返回0。(5)串连接 Concat(s,t) 返回由两个串s和t连接在一起形成的新串。(6)求子串 SubStr(s,i,j) 返回串s中从第i(1iStrLength(s)个字符开始的、由连续j个字符组成的子串。(7)插入InsStr (s,i,t) 将串t插入到串s的第i(1iStrLength(s)+1)个字符中,即将t的第一个字符作为s的 第i个字符,并返回产生的新串 (8)串删除 DelStr (s,i,j) 从串s中删去从第i(1iStrLength(s)个字符开始的长度为j的子串,并返回产生新串。(9)串替换 RepStr (s,s1,s2) 在串s中,将所有出现的子串s1均替换成s2。(10)输出串DispStr(s) 输出串s的所有元素值(11) 判断串是否为空 IsEmpty(s) 为空返回1,不为空返回0编写主函数调用上述函数实现下列操作:(1) 建立串s=“abcdefghijklmn”,串s1=“xyz”,串t“hijk”(2) 复制串t到t1,并输出t1的长度(3) 在串s的第9个字符位置插入串s1而产生串s2,并输出s2(4) 删除s第2个字符开始的5个字符而产生串s3,并输出s3(5) 将串s第2个字符开始的3个字符替换成串s1产生串s4,输出s4 (6) 提取串s的第2个字符开始的10个字符而产生串s5,并输出s5(7) 将串s1和串t连接起来而产生串s4,并输出s4(8) 比较串s1和s5是否相等,输出结果(9) 判断s3是否为空四、源程序代码#include#define MAX 100typedef struct char chMAX; int length; SqString;void StrAssign(SqString &s,char t) /串赋值int i;for(i=0;ti!=0;i+)s.chi=ti;s.length=i;void StrCopy(SqString &s,SqString t) /串复制int i;for(i=0;it.length;i+)s.chi=t.chi;s.length=t.length;int StrEqual(SqString s,SqString t) /判断串相等int same=1,i; if(s.length!=t.length)same=0;elsefor(i=0;is.length;i+)if(s.chi!=t.chi)same=0;break; return(same);int StrLength(SqString s) /计算串长度return(s.length);SqString Concat(SqString s,SqString t) /串连接SqString str;int i;str.length=s.length+t.length;for(i=0;is.length;i+)str.chi=s.chi;for(i=0;it.length;i+)str.chs.length+i=t.chi;return str;SqString SubStr(SqString s,int i,int j)/求子串SqString str;int k;str.length=0;if(is.length|js.length)return str;for(k=i-1;ki+j-1;k+)str.chk-i+1=s.chk;str.length=j;return str;SqString InsStr(SqString s1,int i,SqString s2) /插入int j;SqString str;str.length=0;if(is1.length+1)return str;for(j=0;ji-1;j+)str.chj=s1.chj;for(j=0;js2.length;j+)str.chi+j-1=s2.chj;for(j=i-1;js1.length;j+)str.chs2.length+j=s1.chj;str.length=s1.length+s2.length;return str;SqString DelStr(SqString s,int i,int j) /删除int k;SqString str;str.length=0;if(is.length|i+js.length+1)return str;for(k=0;ki-1;k+)str.chk=s.chk;for(k=i+j-1;ks.length;k+)str.chk-j=s.chk;str.length=s.length-j;return str;SqString RepStr(SqString s,int i,int j,SqString t) /替换int k;SqString str;str.length=0;if(is.length|i+j-1s.length)return str;for(k=0;ki-1;k+)str.chk=s.chk;for(k=0;kt.length;k+)str.chi+k-1=t.chk;for(k=i+j-1;k0)for(i=0;i0)return 0; /不为空elsereturn 1; /为空int main(void)void StrAssign(SqString &s,char t);/串赋值void StrCopy(SqString &s,SqString t);/串复制 int StrEqual(SqString s,SqString t);/判断串相等 int StrLength(SqString s);/计算串长度 SqString Concat(SqString s,SqString t);/串连接 SqString SubStr(SqString s,int i,int j);/求子串 SqString InsStr(SqString s1,int i,SqString s2);/插入 SqString DelStr(SqString s,int i,int j);/删除 SqString RepStr(SqString s,int i,int j,SqString t);/替换 void DispStr(SqString s);/输出串所有元素 int IsEmpty(SqString s);/判断串是否为空 char ch1=abcdefghijklmn,ch2=xyz,ch3=hijk;SqString s,s1,s2,s3,s4,s5,s6,t,t1,t2; int longth,same,kong;StrAssign(s,ch1); /建立串s=abcdefghijklmnStrAssign(s1,ch2); /建立串s1=xyzStrAssign(t,ch3); /建立串thijkStrCopy(t1,t); /将串t复制给t1printf(串t1: ); DispStr(t1);longth=StrLength(t1); /求串t1的长度 printf(串t1的长度为:%dn,longth);printf(串 s: );DispStr(s);s2=InsStr(s,9,s1); /将串s1插入串s的第9个位置,得串s2printf(串s2:); DispStr(s2); /输出串s2s3=DelStr(s,2,5); /删除s第2个字符开始的5个字符而产生串s3,并输出s3printf(串s3:); DispStr(s3); /输出串s3s4=RepStr(s,2,5,s1); /用串s1替换串s中从第2个字符起连续5个字符得到新串s4printf(串s4:); DispStr(s4); /输出串s4 s5=SubStr(s,2,10); /提取串s中第2个字符开始的10个字符而产生串s5 printf(串s5:);DispStr(s5); /输出串s5 s6=Concat(s1,t); /连接串s1和t而产生串
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 选修5:第四章 《生命中的基础有机化学物质》全章分析及章节教学设计特约-人教版-新课标
- 中国邮政2025安庆市秋招信贷审查岗位高频笔试题库含答案
- 第11课 応援 教案 2024-2025学年初中日语人教版七年级第一册
- 中卫市烟草公司2025秋招财务管理岗位面试模拟题及答案
- 8安全记心上 第一课时 教学设计-2024-2025学年道德与法治三年级上册统编版
- 中国邮政2025乐山市秋招合规审计岗位面试模拟题及答案
- 菏泽牡丹区中烟工业2025秋招心理测评题库含参考答案
- 驾校安全教育培训制度课件
- 2024年一级建造师过关检测试卷及完整答案详解一套
- 应急供水工程施工质量控制方案
- 《孤独的小螃蟹》课件
- 企业员工健康管理实施方案
- 河北省 橡胶沥青类应力吸收层施工技术规范 DB13∕T 5314-2020
- 肥料代理合作协议书
- 2024-2030年中国集成智能功率模块(IPM)行业深度调查与发展趋势研究研究报告
- 职业技术学校《药物分析检测技术》课程标准
- 苏教版(2024年新教材)七年级上册生物全册教案
- 自动售货机投放合作合同2024版
- 2021上半年盐城市东台市城投集团试题
- 医院院感检查表格全套汇总
- 火灾报警控制器CAN联网课件
评论
0/150
提交评论