文章编辑(数据结构课程设计).doc
《文章编辑(数据结构课程设计).doc》由会员分享,可在线阅读,更多相关《文章编辑(数据结构课程设计).doc(21页珍藏版)》请在咨信网上搜索。
(完整word版)文章编辑(数据结构课程设计) 课程设计报告 课程设计题目: 文章编辑 学生姓名: 专 业:计算机科学与技术 班 级: 学 号: 指导教师: 2012年 06月21日 目录 一、实验题目 1 二、实验时间、地点 1 三、实验目的 1 四、实验要求 1 五、实现思路 2 1、定义结构体 2 2、主要函数: 2 六、实现过程 4 主要代码: 4 运行结果: 10 七、实验总结 14 八、参考文献 14 一、实验题目 文章编辑:输入一页文字,程序可以统计出字母、数字、空格的个数。静态存储一页文章,每行最多不超过80个字符,共N行; 二、实验时间、地点 第十九周,软件楼603 三、实验目的 本次课程设计的主要目的是综合运用所学的数据结构知识解决一个比较实际问题,侧重对链表、数组、字符串、图、树等相关内容的综合应用,使同学们能进一步熟悉掌握数据结构的基础知识,进一步提升自己的解决问题和编程调试能力,为后续专业课程的学习打下良好的基础。 四、实验要求 (1)分别统计出其中英文字母数和空格数及整篇文章总字数; (2)统计某一字符串在文章中出现的次数,并输出该次数; (3)删除某一子串,并将后面的字符前移。存储结构使用线性表,分别用几个子函数实现相应的功能;输入数据的形式和范围:可以输入大写、小写的英文字母、任何数字及标点符号。 输出形式: (1)分行输出用户输入的各行字符; (2)分4行输出"全部字母数"、"数字个数"、"空格个数"、"文章总字数" (3)输出删除某一字符串后的文章; 五、实现思路 1、定义结构体 定义结构体 struct line,文本行采用顺序存储,行与行之间采用链式存储 2、主要函数: int FindString(LINE * &head,char *str) /*统计str在文章中出现的次数*/ 求在一行中Str出现的次数的流程图: ①.查找第一个字符,如果有第一个字符即p->data[i]==str[0],设计数器k=0 ②.查找这个字符后面的字符与要查找的字符串是否匹配即p->data[i+j]==str[j],如果匹配k++ ③.重复第二步,如果k=len2,则查找到,count++;如果没查找到,重新进行第一步 开始 count=0;h=0;len1=0; len2=strlen(str); p->data[i]==str[0] i++ k=0;j=0; p->data[i+j]==str[j] k++;j++; k=len2 count++; i=i+k-1; 结束 Y N Y N N Y void delstringword(char *s,char *str) /*删除字符串*s中的字符串*str*/ 实现思想: ①.从字符串s中寻找str第一次出现的位置 *p=strstr(s,str); ②.len=strlen(s);i=len-strlen(p)即前i项恰好不含要删除的字符串,将前i项复制到tmp中 ③.j=i+strlen(str) 即要删除的字符串在i+1和j之间,将j之后的字符串复制到tmp中 ④.将tmp赋给串s,返回s str p i j s for(m=0;m<i;m++) tmp[count++]=s[m]; for(n=j;n<len;n++) tmp[count++]=s[n]; tmp 六、实现过程 主要代码: #include <string.h> #include <stdio.h> #include <stdlib.h> #include <conio.h> typedef struct line { char *data; struct line *next; }LINE; void Create(LINE * &head) { printf ("请输入一页文章,以Ctrl+E(^E)为结尾(每行最多输入80字符!):\n"); LINE *p=new LINE; /*首先为链表 建立一个附加表头结点*/ head=p; /*将p付给 表头指针*/ char ch[100]; while(1) { gets(ch); /*输入字符串!*/ if(strlen(ch)>80) { printf("每行最多输入80字符"); break; } if(ch[0]==5)break; /*如果发现输入 ^E,则退出输入*/ p=p->next=new LINE; p->data=new char[strlen(ch)+1]; /*为结点分配空间 */ strcpy(p->data,ch); if(ch[strlen(ch)-1]==5) /*除去最后一个控制符 ^E */ { p->data[strlen(ch)-1]='\0'; break; } } p->next=NULL; /*最后的一个指针为空 */ head=head->next; } /**文本字数统计**/ int Count_Space(LINE* &head)//统计空格数 { LINE *p=head; int asc_space=32; int count=0; int i; int Len; do{ Len=strlen(p->data); for(i=0;i<Len;i++) if(p->data[i]==asc_space) count++; }while((p=p->next)!=NULL); return count; } int Count_Num(LINE * &head)//统计数字个数 { LINE *p=head; int count=0; int Len; int i; do{ Len=strlen(p->data); for(i=0;i<Len;i++) if(p->data[i]>=48 && p->data[i]<=57) count++; }while((p=p->next)!=NULL); return count; } int Count_All_Word(LINE * &head)//统计文章的总字数 { LINE *p=head; int count=0; do{ count+=strlen(p->data); }while((p=p->next)!=NULL); return count; } int Count_Letter(LINE * &head)//统计字母数 { LINE *p=head; int count=0; int Len; int i; do{ Len=strlen(p->data); for(i=0;i<Len;i++) if(p->data[i]>='a' && p->data[i]<='z'||p->data[i]>='A' && p->data[i]<='Z')count++; //计算字母个数 } while((p=p->next)!=NULL); return count; } int Find_Word(LINE * &head,char *sch)//统计 sch 在文章中出现的次数 { LINE *p=head; int count=0; int len1=0; int len2=strlen(sch); int i,j,k; do{ len1=strlen(p->data);//当前行的字符数 for(i=0;i<len1;i++) { if(p->data[i]==sch[0]) { k=0; for(j=0;j<=len2-1;j++) if(p->data[i+j]==sch[j])k=k+1; if(k==len2) {count++;i=i+k-1;} } } }while((p=p->next)!=NULL); return count; } /**特定字符串的删除**/ void del_string_word(char *s,char *sch) { char *p=strstr(s,sch); char tmp[80]; int len=strlen(s); int k,kk; int i=len-strlen(p); int j=i+strlen(sch); int count=0; for(k=0;k<i;k++) tmp[count++]=s[k]; for(kk=j;kk<len;kk++) tmp[count++]=s[kk]; tmp[count]='\0'; strcpy(s,tmp); } void Del_String(LINE * &head,char *sch)//删除指定的字符串 { LINE *p=head; do{ while(strstr(p->data,sch)!=NULL) del_string_word(p->data,sch); }while((p=p->next)!=NULL); } /**打印输入的文本**/ void OutPutTxt(LINE * &head)//向屏幕输出文章 { LINE *p=head; printf("文本文件输出如下:"); do{ printf("%s\n",p->data); }while((p=p->next)!=NULL); } void Count(LINE * &head) { printf("文章统计信息结果如下:\n"); printf("英文字母数:%d\n",Count_Letter(head)); printf("空格数: %d \n",Count_Space(head)); printf("文章中共出现数字:%d\n",Count_Num(head)); printf("文章出现的汉字和标点(全角)总数: %d\n",(Count_All_Word(head)-Count_Num(head)-Count_Space(head)-Count_Letter(head))/2); printf("统计文章的总字数: %d\n",(Count_All_Word(head)+Count_Num(head)+Count_Space(head)+Count_Letter(head))/2); printf("\n"); } void main() { LINE *head; char sch[20]; char ID[10]; char ch; char tmp_sch[20]; printf(" 文章编辑系统 \n"); printf(" 主菜单如下:\n"); while(1) { printf(" *******************************************************************\n"); printf(" 1.新建文本\n"); printf(" 2.浏览输入文本\n"); printf(" 3.文本字符统计\n"); printf(" 4.特定字符串的统计\n"); printf(" 5.特定字符串的删除\n"); printf(" 6.退出\n"); printf(" *******************************************************************\n"); printf("注:请您按关键字代号选择菜单操作!如是第一次操作,务必先选第一步!\n"); printf("请输入序号:"); scanf("%s",ID); while(1) { if(strcmp(ID,"1")==0) { printf("新建文本要覆盖已有文本,是否继续输入?(Y/N)\n"); getchar(); scanf("%c",&ch); system("cls"); if(ch=='n'||ch=='N') break; else if(ch=='y'||ch=='Y') Create(head); break; } else if(strcmp(ID,"2")==0) { system("cls"); OutPutTxt(head); break; } else if(strcmp(ID,"3")==0) { system("cls"); OutPutTxt(head); printf("\n"); Count(head); break; } else if(strcmp(ID,"4")==0) { system("cls"); printf("请输入要统计的字符串:"); scanf("%s",sch); printf("\n"); OutPutTxt(head); printf("\n"); printf("出现的次数为: %d\n",Find_Word(head,sch)); break; } else if(strcmp(ID,"5")==0) { system("cls"); printf("请输入要删除的某一字符串:"); scanf("%s",tmp_sch); printf("\n"); OutPutTxt(head); Del_String(head,tmp_sch); printf("删除后"); OutPutTxt(head); break; } else if(strcmp(ID,"6")==0) { printf("你确定要退出系统吗?(Y/N)\n"); getchar(); scanf("%c",&ch); system("cls"); if(ch=='n'||ch=='N') break; else if(ch=='y'||ch=='Y') exit(0); } else { system("cls"); printf("您输入字母有错,请重新输入!\n\n"); break; } } } } 运行结果: 1、主界面 2、新建文本界面 3、浏览文本 4、文本字符统计 5、特定字符串统计 6、特定字符串删除 七、实验总结 本次课程设计历时一周,所用知识基本上包括了课本所学的知识以及很多有关C++的基础知识,课程设计的过程中自己更更进一步了解了链表,掌握了数据结构的思想与方法,也使我认识到自己在学习编程方面还有很多的不足。自己在编写程序的过程中,不是所有知识一下就想起来的,而是出现了不少错误,通过调试,在查阅一些资料后,才整理出来的。今后我要多读一些编程方面的书籍,不能只拘泥于课本上的知识,并注重理论与实践的结合,多上机练习编写程序,提高自己的实际动手能力和独立思考的能力,不断充实自己,更好的掌握编程思想。我相信,随着时间的积累系统中很多内容都将得到充实。 其实,系统中也有不少亮点,比如:统计出汉字个数,strstr()函数的应用,链表的运用,清屏函数等。 八、参考文献 《数据结构(c++版)》第二版 李根强 中国水利水电出版社 《C语言程序设计》 第二版 谭浩强 清华大学出版社 20- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 文章 编辑 数据结构 课程设计
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文