



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
设计名称:串的查找和替换设计内容:打开一篇英文文章,在该文章中找出所有给定的单词,然后对所有给定的单词替换为另外一个单词,再存盘.串(string)是由零个或多个字符组成的有限序列,一般记为s=a1a2(n大于零)。通常称字符在序列中的序列号为该字符在串中的位置,子串在主串中的位置则以字串的第一个字符在主串中的位置来表示。当两个串的每个字符都相等,成这两个串是相等的。设计思路:在字串的查找定位过程中,利用技术指针一指示被替换串和替换串中当前正待在比较好的位置,所用算法的基本思想事:首先利用指针i来完成呗替换串和替换在文本中的遍历,从被替换和替换串的第一个字符起进行比较,若相等继续比较后续字符;否则完成一次比较,指针i递增进行下一次的比较。以此类推,直至匹配成功。具体分析: 首先在G盘里存入一篇“I have a dream”的文章,文件名为abc.txt。利用标准库函数fopen()打开一个文件,然后从文件中读取字符串保存在数组中,完成文件的读入。其次,根据键盘输入的选择命令(1-4)程序调用不同功能模块来完成相应的操作。 本设计采用的数据结构 #define SIZE 20 /* 查找单词字符和输入替换单词少于20 */ #define MAXLEN 10000 /* 文章字符不大于10000 */ char keyWordsSIZE; /* 查找单词 */ char copyWordsSIZE;/* 替换单词 */ char strOneMAXLEN; /* 将未改文章的所有字符储存在里面 */ char strTwoMAXLEN; /* 将改后文章的所有字符储存在里面 */ 程序中用户选择命令(数字1-4)设置: 1.文本显示:程序运行后显示主菜单,提示用户根据需要选择不同的命令操作。程序根据键盘输入的选择命令(数字1-4)调用不同功能模块来完成相应的操作。如果用户输入的命令事1,主函数调用函数从文件进行初始化数组,利用标准输入函数将该数组输出到标准输出上;如果用户输入的是命令2,主函数调用函数查找匹配的字符串连同匹配的字符串个数一并输出到标准输出上;如果用户输入的命令是3,主函数调用替换函数,将文章中替换的内容替换掉;如果用户输入的是命令4,程序自动退出。程序流程图如下: 程序代码及运行结果: #include #include #define SIZE 20 /* 查找单词字符和输入替换单词少于20 */ #define MAXLEN 10000 /* 文章字符不大于10000 */ void main(void) int i, j; int flag; /* 用于标记匹配单词 */ int countFlag; /* 用于检查匹配计数 */ int countOne = 0; /* 记录未改文章字符个数 */ int countTwo = 0; /* 记录改后文章字符个数 */ char keyWordsSIZE; /* 查找单词 */ char copyWordsSIZE;/* 替换单词 */ char strOneMAXLEN; /* 将未改文章的所有字符储存在里面 */ char strTwoMAXLEN; /* 将改后文章的所有字符储存在里面 */ FILE *fp; printf(请输入要查找的单词: ); gets(keyWords); printf(请输入要替换的单词: ); gets(copyWords); if (NULL = (fp = fopen(c:abc.txt, rt+)/* 读文件 */ printf(文件打开失败!n); exit(1); while (!feof(fp)/* 读文件 */ strOnecountOne+ = fgetc(fp); countOne-;/* 减去最后一个文件结束字符 */ for (i=0; icountOne; i+) if (keyWords0 = strOnei)/* 判断查找单词第一个字符是否匹配 */ if ( = strOnei-1) | (n = strOnei-1) | (0 = i)/* 1.检查单词前的一个字符 */ flag = 1; countFlag = i + 1; for (j=1; keyWordsj!=0; j+) if (keyWordsj != strOnecountFlag+)/* 是否匹配 */ flag = 0; break; if ( = strOnecountFlag) | (n = strOnecountFlag) | (EOF = strOnecountFlag)/* 2.检查单词后的一个字符 */ if (1 = flag)/* 若匹配,则进行拷贝 */ i = countFlag-1; for (j=0; copyWordsj!=0; j+) strTwocountTwo+ = copyWordsj; else/* 另外 */ strTwocountTwo+ = strOnei; else/* 另外 */ strTwocountTwo+ = strOnei; else/* 另外 */ strTwocountTwo+ = strOnei; fclose(fp); if (NULL = (fp = fopen(c:abc.txt, w)/* 写入文件 */ printf(文件打开失败!n); exit(1); for (i=0; icountTwo; i+)/* 写入文件 */ fputc(strTwoi, fp); fclose(fp); 执行程序输出为: 请输入要查找的单词:dream请输入要替换的单词:plane程序运行完毕,原文档中所有的dream均被替换为plane,并保存修改后的文章.调试分析在调试程序中我遇到了一些问题,主要内容如下:(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 标准厂房及配套基础设施建设项目经济效益和社会效益分析报告
- 2025劳动合同模板范本(用人单位参考)
- 生物质绿色甲醇生产线项目风险评估报告
- 焊丝生产制造项目环境影响报告书
- 汉语基础的试题及答案
- 100MW风电场项目社会稳定风险评估报告
- 智慧康养中心综合建设项目社会稳定风险评估报告
- 职高英语基础试题及答案
- 新能源汽车轻量化零部件智能制造项目建设工程方案
- 基础英语试题及答案
- 颅脑损伤后的代谢变化和营养支持
- 介入科规培出科小结
- 人工智能在国际贸易中的应用
- 视频监控调取记录表
- 第2章 Windows 10操作系统
- 教研活动:幼儿园班级主题墙创设课件
- GB/T 42430-2023血液、尿液中乙醇、甲醇、正丙醇、丙酮、异丙醇和正丁醇检验
- 酒店住宿水单模板-可修改
- SF-三福的历史与文化 v2.0
- 幼儿园故事《小红帽》PPT模板
- GB/T 6723-2017通用冷弯开口型钢
评论
0/150
提交评论