- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
课程设计串的查找与替换
学号 《》
课程设计报告
串的查找与替换 专业: 计算机科学与技术(对口) 班级: 姓名: 指导教师: 成绩:
目录
1设计目的及要求 1
1.1问题描述 1
1.2内容要求 1
2设计内容 1
2.1现根据问题描述作如下分析 2
2.1.1本设计所采用的数据结构 2
2.1.2程序中各部分功能函数 2
2.1.3程序设计流程图 3
3设计调试 4
4设计总结 9
5参考文献 10
6源程序 11
1设计目的及要求
数据结构课程设计的目的是:通过设计掌握数据结构课程中学到的基本理论和算法并综合运用于解决实际问题中,它是理论与实践相结合的重要过程。设计要求会如何对实际问题定义相关数据结构,并采用恰当的设计方法和算法解决问题,同时训练学生进行复杂程序设计的技能和培养良好的程序设计习惯。
1.1问题描述
打开一篇英文文章,在该文章中找出所有给定的单词,然后对所有给定的单词替换为另外一个单词,再存盘。
1.2内容要求
(1)根据题目要求进行需求分析,分析出该项任务的主要功能和设计重点。
(2)根据需求分析的内容划分模块
(3)进行程序设计
2设计内容
计算机上的非数值处理的对象基本上上字符串数据,字符串一般简称为串。串(string)是由零个或多个字符组成的有限序列,一般记为s=`a1a2…an`(n大于零)。通常称字符在序列中的序号为该字符在串中的位置,子串在主串中的位置则以子串的第一个字符在主串中的位置来表示。当两个串的每个字符都相等时(串值相等),称这两个串是相等的。
在子串的查找定位过程中,分别利用计数指针j和k指示被替换串和替换串中当前正待比较的字符位置。所用算法的基本思想是:首先利用指针i来完成被替换串和替换串在文本中的遍历,从被替换串和替换串的第一个字符起进行比较,若相等则继续逐个比较后续字符;否则完成一次比较,指针i递增进行下一次的比较。以此类推,直至匹配成功。
2.1现根据问题描述作如下分析
首先利用标准库函数fopen()打开一个文件,然后从文件中读取字符串保存到数组中,完成文件的读入。其次,根据键盘输入的选择命令(数字1~4)程序调用不同功能模块来完成相应的操作。
2.1.1本设计所采用的数据结构
char String[65535]; //长度要大于输入文本文件的长度!
char findstring[50]; //输入的要查找的字符
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.1.3程序设计流程图如图(一)所示
图1程序流程图
程序运行后显示主菜单,提示用户根据需要选择不同的命令操作。程序根据键盘输入的选择命令(数字1~4)调用不同功能模块来完成相应的操作。如果用户输入的命令是“1”,主函数调用InitStr()函数从文件进行初始化数组,利用标准输入函数将该数组输出到标准输出上;如果用户输入的命令是“2”,主函数调用FindStrings()函数查找匹配的字符串并连同匹配的字符串个数一并输出到标准输出上;如果用户输入的命令是“3”,主函数调用Replace()函数,将String中要替换的内容替换掉;如果用户输入的命令是“4”,程序自动退出。
3设计调试
程序的开发与调试均在Microsoft Visual C++环境下进行。
首先程序运行后显示程序的主菜单,主菜单命令选择设置“1”:文本文件显示;“2”:子串查找;“3”:子串替换;“4”:退出整个程序。程序根据用户输入的命令(数字1~4)进行相应的操作。
主菜单显示如图(二):
图2程序主菜单
在程序主菜单中任意输入命令进行测试。输入命令一,如图(三):
图3程序主菜单 命令输入一
输入命令一后程序的运行结果:显示文本文件的内容。如图(四):
图4程序命令一的运行结果
输入命令二后程序的运行结果:选择命令二,进行字符串的查找测试。从
文档评论(0)