数据结构课程设计回文数问题.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
. . . 湖南科技学院 课程设计报告 课程名称: 数据结构课程设计 课程设计题目: 02、回文问题 系: 专 业: 年级、班: 姓 名: 学 号: 指导教师: 职 称: 2011年12月 目录 问题描述----------------------------------------------------------------------3 具体要求----------------------------------------------------------------------3 测试数据----------------------------------------------------------------------3 算法思想----------------------------------------------------------------------3 模块划分----------------------------------------------------------------------4 数据结构----------------------------------------------------------------------4 源程序------------------------------------------------------------------------7 测试情况--------------------------------------------------------------------14 设计总结--------------------------------------------------------------------14 参考文献--------------------------------------------------------------------15 问题描述 利用栈跟队列找出一个TXT文档中所有的回文单词并输出。回文单词就是单词中字母从前往后拼与从后往前拼得出的单词是一样的,如:AaA、121、1221、d、did等,从数据结构角度看,栈和队列是特殊的线性表,其特殊性在于栈和队列的基本操作是线性表操作的子集,它们是操作受限的线性表,而栈是一种限定仅在表尾进行插入或删除的线性表,栈的修改是按先进后出的顺序进行的,队列是一种先进先出的线性表,它只允许在表的一端进行插入,而在另一端进行删除,因此可利用栈和队列的这两个性质对一个单词是否为回文单词进行检测,如果是则输出这个单词即可。一句话里可能既包含字母、数字还可能包含标点符号,回文单词的判断是不包含标点符号的 ,但文件输入流读取的时候标点也被一起读取进来了,因此要删除紧跟单词后中的标点符号,单独对各个单词进行判断。 二、具体要求 此课程设计要求编写程序以实现检测出文档中的回文单词并将其输出的功能,首先要将每一个单词从文档读取出来,其次对每一个单词进行回文判断,主程序用栈和队列实现,以进一步巩固、理解和熟练掌握栈和队列的基本操作;同时对文本文件进行读取数据要利用到文件输入流的知识。 三、测试数据 用文本文档data.txt,进行测试,输出回文数,及个数。文本文档中除英文字母,数字,常见标点符号外无其他字符,并且编码采用常见的ANSI编码。 四、算法思路 1、初始化栈和队列,读入TXT文本文档,若文档不能正常读入,则输出文档读入错误,若正常读入,文档非空则将文档中的单词逐个读入到字符串中。 2、因为标点符号都是紧跟单词后的,故对每个字符串首先得判断最后一个字符c,若c既不是字母也不是数字,字符串的长度减一,即以标点符号结束的字符串最后一个字符不压入栈跟队列,不参与回文单词的判断。 3、调用出栈与出队列函数,逐个比较出栈与出队列字符是否一样,用count记录栈中出来的与队列出来的相同字符的个数,若count==str .length()则说明该字符串从栈中出来跟从队列出来完全一样,即字符串完全对称,为回文单词,输出,回文单词加一个,否则什么也不做。 4、读取至文本文档最后时,程序结束,关闭文本文档,同时销毁队列。 5、假设文本文档中除英文字母,数字,常见标点符号外无其他字符,并且编码采用常见的ANSI编码。 五、模块划分 函数功能: void initStack(SqStack s);//构造一个空栈s void clearStack(SqStack s);//清空栈 bool isEmpty(SqStack s);//判断栈是否为空 bool isFull(SqStack s);//判断栈是否满 v

文档评论(0)

文档分享 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档