数据结构课程设计—文章编辑.doc

上传人:仙人指路1688 文档编号:2396809 上传时间:2023-02-17 格式:DOC 页数:11 大小:199KB
返回 下载 相关 举报
数据结构课程设计—文章编辑.doc_第1页
第1页 / 共11页
数据结构课程设计—文章编辑.doc_第2页
第2页 / 共11页
数据结构课程设计—文章编辑.doc_第3页
第3页 / 共11页
数据结构课程设计—文章编辑.doc_第4页
第4页 / 共11页
数据结构课程设计—文章编辑.doc_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《数据结构课程设计—文章编辑.doc》由会员分享,可在线阅读,更多相关《数据结构课程设计—文章编辑.doc(11页珍藏版)》请在三一办公上搜索。

1、 成 绩10信计2011-2012(一)数 据 结 构 课 程 设 计设计题目 文章编辑 设计时间 2011.12.29 至 2012.1.4 学生姓名 学生学号 所在班级 指导教师 徐州工程学院数学与物理科学学院文章编辑一、需求分析 本次课程设计,我做的是文章编辑。任务与要求包括:输入一页文字,程序可以统计出文字、数字、空格的个数。静态存储一页文章,每行最多不超过80个字符,共N行;要求(1)分别统计出其中英文字母数和空格数及整篇文章总字数;(2)统计某一字符串在文章中出现的次数,并输出该次数;(3)删除某一子串,并将后面的字符前移。存储结构使用线性表,分别用几个子函数实现相应的功能。输入数

2、据的形式和范围:可以输入大写、小写的英文字母、任何数字及标点符号。输出形式:(1)分行输出用户输入的各行字符;(2)分4行输出全部字母数、数字个数、空格个数、文章总字数(3)输出删除某一字符串后的文章。运行环境包括: Windows xp操作系统、Visual C+6.0编译环境。二、概要设计对于文章的处理,我用的是for语句查找,即将符合条件的字符查找出来,然后通过函数实现字符的统计,删除等操作。同时,存储用线性表的链表结构,然后通过设计四个函数,实现设计要求的4个基本功能。1、 主要模块的描述用while语句进行编写:while(L-next)for (p = L, q = s; *q !

3、= 0 & p-next; p = p-next, q+)if (p-c != *q) break;if (*q = 0) n+;L = L-next;将链表指针指向输入的字符串开始字符,和文章中字符的首位,然后使用循环语句,将字符串的每一个字符依次比较,判断相同的字符,以便实现其他的查找,统计,删除等功能。2、程序流程框图如图所示输入文章,确定操作选择进行编辑退出完成 退出是否3、各功能函数描述本次设计共分为四个函数,分别实现四个功能:(1)统计文章中的字符数,空格数,数字等void print2(ca *L, int &p1, int &p2, int &p3, int &n) / 统计字

4、符信息;(2)删除输入的某一段字符void print2(ca *L, int &p1, int &p2, int &p3, int &n) / 统计字符信息;(3)字符串删除:vca *DelStr(ca *L) /删除某一字段,统计某一字符,函数为:void StrNo(ca *L)三、详细设计1、存储结构设计线性表是最基本、最简单、也是最常用的一种数据结构。线性表中数据元素之间的关系是一对一的关系,即除了第一个和最后一个数据元素之外,其它数据元素都是首尾相接的。线性表的逻辑结构简单,便于实现和操作。因此,线性表这种数据结构在实际应用中是广泛采用的一种数据结构。在实现线性表数据元素的存储方

5、面,一般可用顺序存储结构和链式存储结构两种方法。本程序中采用链式存储。2、算法设计本课程设计中用指针链表,配合循环语句,完成字符串比较功能,从而完成统计字符串,删除字符串,统计字符信息的功能。字符串删除:如果,输入字符的第一个字母与文本中的元字符有相同的时候,执行第一个for循环语句,对原文中的字符依次和输入的字符串比较,有不相同的跳出,如果完全相同,则将P指针给H指针,从而达到删除的作用。然后,进行上述操作,完成删除操作。3、程序运行流程说明程序运行时首先从主函数开始,先判断选择的操作。然后根据要求进行相应的查找,删除,统计,显示的操作,一次操作完之后,会回到开始的选择界面,用户可重新选择操

6、作,如果用户选择退出,程序就停止。#include#include #include /文本每行以字符串形式存储,行与行之间以链表存储typedef struct line char *data; struct line *next;LINE;templateclass wenbenpublic:Create(LINE * &head);CountLetter(LINE * &head);CountNumber(LINE * &head);CountSpace(LINE * &head);CountAll(LINE * &head);FindString(LINE * &head,char *

7、str);delstringword(char *s,char *str);OutPut(LINE * &head);void Create(LINE * &head) cout请输入文本,以Ctrl+E(E)为结尾,每行最多输入80字符!80) coutnext=new LINE; p-data=new charstrlen(tmp)+1; strcpy(p-data,tmp); if(tmpstrlen(tmp)-1=5) p-datastrlen(tmp)-1=0; break; p-next=NULL; head=head-next;/=/统计字母数int CountLetter(LI

8、NE * &head) LINE *p=head; int count=0;do int Len=strlen(p-data); for(int i=0;idatai=a&p-dataidatai=A&p-datainext)!=NULL); return count; /=/统计数字数int CountNumber(LINE * &head) LINE *p=head; int count=0; do int Len=strlen(p-data); for(int i=0;idatai=48 & p-datainext)!=NULL); return count;int CountSpace

9、(LINE * &head) LINE *p=head; int count=0; do int Len=strlen(p-data); for(int i=0;idatai=32)count+; while(p=p-next)!=NULL); return count;int CountAll(LINE * &head) LINE *p=head; int count=0; do count+=strlen(p-data); while(p=p-next)!=NULL); return count;int FindString(LINE * &head,char *str) LINE *p=

10、head; int count=0; int h=0;int len1=0; int len2=strlen(str); int i,j,k; do len1=strlen(p-data); for(i=0;idatai=str0)k=0; for(j=0;jdatai+j=strj) k+;if(k=len2)count+;i=i+k-1; while(p=p-next)!=NULL); return count;void delstringword(char *s,char *str)char *p=strstr(s,str); char tmp80; int len=strlen(s);

11、 int i=len-strlen(p); int j=i+strlen(str); int count=0; for(int m=0;mi;m+)tmpcount+=sm; for(int n=j;ndata,str)!=NULL)delstringword(p-data,str);while(p=p-next)!=NULL); void OutPut(LINE * &head) LINE *p=head; do coutdatanext)!=NULL); void main()LINE *head; Create(head);cout文章为:endl;OutPut(head);couten

12、dl全部字母数:CountLetter(head)endl;cout数字个数:CountNumber(head)endl;cout空格个数: CountSpace(head)endl;cout文章总字数: CountAll(head)endl;char str120,str220;coutendlstr1;coutstr1出现的次数为:FindString(head,str1)endl;coutendlstr2;DelString(head,str2); cout删除str2后的文章为:endl;OutPut(head); 四、调试分析设计程序初犯了一些错误,开始的布局比较混乱,程序为一块一块

13、,连接不当,后来查看了别人的优秀作品仿照它们的顺序,完成了相对较为有序的程序。并且一开始在自己的电脑上运行时,出现了不少错误不能运行,为设计增加了难度。根据调试时提示的错误加上同学的帮忙,最后运行成功。为了避免在调试过程中出现输入错误的情况,写代码时写明注释对测试和寻找错误节省了很多时间。首先,在程序中输入一段文字,便实现统计这段文字中英文字符,空格,数字,和文章总字数的功能,如下图:接着,对上面的文字进行统计字符数的操作,比如输入字符 chen ,统计到的字符数为4,如下图所示:对输入的文字进行字符删除的操作,比如输入字符yue,如图所示五、课设总结本程序的设计目的是能更好更快的解决文章编辑

14、问题。经过测试和试用,我相信本程序达到了方便和实用的设计目的,并在程序的实现方面有着独到之处。这次课程设计使我对做自己真正的了解了。我真正体会到了在整个过程给我带来的无奈与快乐。可是我对数据结构掌握的还不行,在设计数据结构时候许多东西东都不会。我终于认识到问题的根源所在。然后我只好再次认真细致地对开发过程进行了规划和分析,才逐渐弄清了整个程序的流程。在编写这个程序的过程中,我复习了之前学的基本语法,更加深刻的认识到循环是大部分程序的基本要素。结合了这学期学的数据结构,分析算法的时间复杂度,不断改进算法,更加巩固了之前学的知识,比以前更能灵活运用。最后,这次课程设计给了我很大的好处,让我了解到自己的许多不足,让我知道以后一定要好好学习,不能再像以前那么懒散了。并且让我知道不管什么难题,只要尽自己的去努力去寻找问题的答案,最终一定能顺利解决。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号