- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
学号
2014-2015学年第一学期
《数据结构》
课程设计报告
题目:串的查找与替换
专 业:计算机科学与技术(对口)
班级:
姓名:
指导教师:
成绩:
目录
TOC \o 1-5 \h \z \o Current Document \h 1设计目的及要求 1
\o Current Document \h 1.1问题描述 1
\o Current Document \h 1.2内容要求 1
\o Current Document \h 2设计内容 1
\o Current Document \h 2.1现根据问题描述作如下分析 2
2.1.1本设计所采用的数据结构 2
2. 1.2程序中各部分功能函数 2
2. 1?3程序设计流程图 3
\o Current Document \h 3设计调试 4
\o Current Document \h 4设计总结 9
\o Current Document \h 5参考文献 10
\o Current Document \h 6源程序 11
1设计目的及要求
数据结构课程设计的目的是:通过设计掌握数据结构课程中学到的基木理 论和算法并综合运用于解决实际问题中,它是理论与实践和结合的重要过程。 设计耍求会如何对实际问题定义相关数据结构,并采用恰当的设计方法和算法 解决问题,同时训练学生进行复杂程序设计的技能和培养良好的程序设计习 惯。
1.1问题描述
打开一篇英文文章,在该文章屮找出所有给定的单词,然后对所有给定的 单词替换为另外一个单词,再存盘。
1.2内容要求
(1) 根据题冃要求进行需求分析,分析出该项任务的主要功能和设计重点。
(2) 根据需求分析的内容划分模块
(3) 进行程序设计
2设计内容
计算机上的非数值处理的对象基木上上字符串数据,字符串一般简称为 串。串(string)是由零个或多个字符组成的有限序列,一般记为s=Sla2???an、(n 大于零)。通常称字符在序列中的序号为该字符在串中的位置,子串在主串中 的位置则以子串的第一个字符在主串屮的位置來表示。当两个串的每个字符都 相等吋(串值相等),称这两个串是相等的。
在子串的查找定位过程中,分别利用计数指针j和k指示被替换串和替换
串中当前正待比较的字符位置。所用算法的基本思想是:首先利用指针i来完 成被替换串和替换串在文本中的遍历,从被替换串和替换串的第一个字符起进 行比较,若相等则继续逐个比较后续字符;否则完成一次比较,指针i递增进 行下一次的比较。以此类推,直至匹配成功。
2.1现根据问题描述作如下分析
首先利用标准库函数fopen()打开一个文件,然后从文件屮读取字符串保 存到数组中,完成文件的读入。其次,根据键盘输入的选择命令(数字1?4) 程序调用不同功能模块来完成相应的操作。
2.1.1本设计所采用的数据结构
char String[65535]; 〃长度要大于输入文木文件的长度!
char findstring[5O]; 〃输入的要查找的字符
char replaceString [50]; //输入的替换后的 string
2?1?2程序中各部分功能函数
void InitStr()/*从文件初始化数组*/;
void InputReplaceChar ()/*输入要替换的字符串*/;
int FindString ()/*查找第一个出现要查找字符的下标*/;
void FindStrings ()/*查看文章中共有多少个要查找的字符*/;
void Insert (char source!],int index,char dest[])/*从指定的下标开始插入 dest 数组屮的元素*/;
void Replace ()/*将Str中要替换的内容替换掉*/;
void Save()/*保存修改后的文章信息*/;
void Menu ()/*程序主菜单*/。
程序中用户选择命令(数字1~4)设置:
“1”:文本文件显示;
“2”:子串查找;
“3”:子串替换;
“4”:退出整个程序。
2丄3程序设计流程图如图(一)所示
图1程序流程图
程序运行后显示主菜单,提示用户根据需要选择不同的命令操作。程序根 据键盘输入的选择命令(数字1?4)调用不同功能模块来完成相应的操作。如 果用户输入的命令是“1”,主函数调用InitStr()函数从文件进行初始化数组, 利用标准输入函数将该数组输出到标准输出上;如果用户输入的命令是“2”, 主函数调用FindStrings()函数查找匹配的字符串并连同匹配的字符串个数一并 输出到标准输出上;如果用户输入的命令是“3”,主函数调用Replace。函数,
将String中要替换的内容替换掉;如果用户输入的命令是“4”,程序自动退出
您可能关注的文档
最近下载
- 2025入团积极分子考试题库(含答案).pdf VIP
- 2024中职专业目录(新版).docx VIP
- 迪斯尼音乐厅的建筑与声学.pdf VIP
- 第6章空间力系分解.ppt VIP
- 2025年部编人教版(统编新教材)小学语文二年级上册教学计划及进度表.docx
- 2025年肺功能检查测试题及答案.doc VIP
- 2025年高考数学全国新课标Ⅱ卷试卷评析及备考策略(课件).pptx VIP
- 酒吧调研报告.pptx
- 第8课《回忆鲁迅先生》课件 (共45张ppt) 2025-2026学年统编版语文八年级上册.pptx VIP
- 2023版《思想道德与法治》(绪论-第一章)绪论 担当复兴大任 成就时代新人;第一章 领悟人生真谛 把握人生方向 第3讲 创造有意义的人生.pptx VIP
文档评论(0)