下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、课程设计报告课程设计题目:文章编辑专业:信息工程班级:1720601学生姓名 :指导教师 :、实验目的及要求:任务:输入一页文字,程序可以统计出文字、数字、空格的个数。静态存储一页文章,每行最多不超过 80 个字符,共 N 行;要求:( 1)分别统计出其中英文字母数和空格数及整篇文章总字数;( 2)统计某一字符串在文章中出现的次数,并输出该次数;( 3)删除某一子串,并将后面的字符前移。存储结构使用线性表,分别用几个子函数实现相应的功能; 输入数据的形式和范围: 可以输入大写、 小写的英文字母、任何数字及标点符号。输出形式:( 1)分行输出用户输入的各行字符;( 2)分 4 行输出全部字母数、
2、数字个数、空格个数、文章总字数( 3) 输出删除某一字符串后的文章;实验时间、地点 :一、概要设计(实验思路)1. 问题分析本程序是对一段英文文章的内容进行处理,存储方式采用链式存储。对于文本的输入, 采用头插法将文本信息存储到链表已申请好的存储空间中, 在此部分设计中最大的问题在于输入文章过程中输入的字符数大于 80 时如何换行;对于文本内容的统计,使用循环对已存储的文章进行匹配,字母数、空格数、数字数直接通过比较即可得到;对于文本内容的处理, 查找部分仍是使用循环对已存储的文章进行匹配, 判断需要查找的字符或者字符串是否与文章中某部分内容相同, 如果存在相同的记录相同的个数及位置并输出个数
3、及位置。删除部分先使用程序的查找功能对文章中需要删除的字符或者字符串进行查找,然后对其进行删除。2. 数据结构选择本程序是对输入的文字进行操作,故使用的数据结构为单链表操作。根据第一部分的问题分析有该链表操作有3 部分:另有全局变量*head ,作为文章的头指针。创建结构体:typedef struct listchar data80; /记录一行字符int length;/记录一行字符长度struct _list *next; /后继指针struct _list *pre; /前趋指针int row;/记录整篇文章的行数LinkList;在文章内容创建部分中使用线性表的链式存储,并使用全局变
4、量对文本的各种信息进行存储;文章的读取、内容统计、删除、查找都采用链表操作完成。3. 流程图( 1)主框架:( 2)文章内容统计子菜单( 3) 文章内容处理子菜单SearchWord( 函数实现 章内 函数内容删 DeleteWord() 容处 显示当前内Printword () 理子菜 返回主菜单单 退出程序)使用函数列表及关系图(4函数名:CreatWord()文本输入函数,对文本的内容进行输入1、PrintWord()、当前文本内容输出函数,将当前存储在链表中的文本内容输出2 文章内容统计函数, 对存储在链表中文本内容进行统计CountWord()、 56、 SearchWord()文章
5、内容查找函数7、 DeleteWord()文章内容删除函数8、 Bmenu()文本内容处理菜单函数9、 AboutWord()显示作者信息的函数10、menu()主菜单函数11、main()主函数关系图 :二、详细设计 ( 实验过程 )1、数据结构定义typedef struct listchar data80; /*记录一行字符 */int length; /*记录一行字符长度 */struct list *next; /*后继指针 */struct list *pre; /*前趋指针 */int row;/*记录整篇文章的行数*/LinkList;2、全局变量定义LinkList *hea
6、d; /*定义全局变量 *head ,文章首行头指针*/int NUM,C,N; /*定义全局变量, Num用来记录行号, C用来记录子串在主串中出现的总次数*/3、函数说明( 1) CreatWord() 文本创建函数LinkList *CreatWord()LinkList *temp;char ch;int i,j;head->next=(LinkList *)malloc(sizeof(LinkList); /head->pre=NULL;temp=head->next; /temp->pre=NULL;temp->length=0;for(i=0;i&l
7、t;80;i+)temp->datai='0't*n);printf(t*创建文本*n);t*n);printf(t请输入文章(输入#号结束): nn);for(j=0;j<Link_Size;j+)for(i=0;i<80;i+)ch=getchar();temp->datai=ch;temp->length+;if(ch='#')NUM=j;break;if(ch='#')temp->length=i;temp->next=NULL;break;temp->next=(LinkList *)ma
8、lloc(sizeof(LinkList) ;temp->next->pre=temp;temp=temp->next;for(i=0;i<80;i+)temp->datai='0'temp->row=NUM+1;system(cls);return (temp);说明:a、 定义 LinkList指针变量 *temp : LinkList *temp;b、 定义文本输入变量ch ,记录文本行数变量j ,记录每行字符数变量i ;c、 申请动态存储空间:head->next=(LinkList*)malloc(sizeof(LinkLis
9、t);d、 首行头指针的前驱指针为空:head->pre=NULL;首行指针:temp=head->next;首行指针的前驱指针也为空:temp->pre=NULL;定义没输入字符时文章长度为0:temp->length=0;初始化为字符串结束标志,防止出现乱码:for(i=0;i<80;i+)temp->datai='0'e、 利用循环进行文本输入for(j=0;j<LINK_INIT_SIZE;j+)/控制一页 for(i=0;i<80;i+) /控制一行ch=getchar(); /接收输入字符指向的行赋值temp 给tem
10、p->datai=ch; /····temp->length+;/行中字符长度加1if(ch='#')NUM=j; break; /文章结束时, Num来记录整个文章的行数在字符输入的过程中, 如果在单行输入的字符超过了则需要以下操作:输入字符数大于80,重新分配空间建立下一行:80 个字符,temp->next=(LinkList *)malloc(sizeof(LinkList) ;给 temp 的前驱指针赋值: temp->next->pre=temp;temp 指向当前行:temp=temp->
11、next;将下一行初始化为字符串结束标志,防止出现乱码:for(i=0;i<80;i+)temp->datai='0'记录整个文章的行数:temp->row=NUM+1;返回指向最后一行指针:return temp;文本输入部分到此结束。( 2) PrintWord() 文章显示函数void PrintWord()int i,j;LinkList *p;p=head->next;system(cls);printf();t*n);printf(t*文本显示*n);t*n);printf(当前文章的内容是:n);for(j=0;j<=NUM&
12、&p!=NULL;j+)for(i=0;(i<80)&&(p->datai)!='#'i+)printf(%c,p->datai);p=p->next;说明:a、 定义文本行数变量j ,每行字符数i : int i,j;LinkList *p;定义指针变量:、b将指针 p 指向链表表头: p=head->next; c、 d 利用循环输出链表中信息:for(j=0;j<=NUM&&p!=NULL;j+)=for(i=0;(i<80)&&(p->datai)!='#
13、39;i+)=printf(%c,p->datai);p=p->next; 文本显示部分到此结束。) CountWord()文章内容统计函数(3voidCountWord()LinkList *temp;char ch;int i,j,t;int WORD=0,word=0,space=0,num=0,sum=0;temp=head->next;for(j=0;j<=NUM;j+)for(i=0;(i<80)&&(temp->datai)!='#'i+)ch=temp->datai;if(ch>='A
14、9;)&&(ch<='Z')WORD+;else if(ch>='a')&&(ch<='z')word+;else if(ch>='0')&&(ch<='9')num+;else if(ch=' ')space+;sum=WORD+word+num;while(1)printf();printf();printf();t*n);*n);printf(t*文章内容统计子菜单t*n);%d数的母章printf(t*文中 字个:
15、n,WORD+word);: %d n,num);的个数数字文章中printf(t*printf(t*文章中空格的个数 :%dn,space);printf(t*文章中所有字的个数:%dn,sum);printf(t*1、退出返回主菜单*n);printf(t*2、直接退出本系统*n);t*n);printf(t请选择: );scanf(%d,&t);if(t=1)system(cls);break;else if(t=2)exit(0);elseprintf(t对不起,无此功能! 请回车重新选择!.n);printf(t);fflush(stdin);getchar();说明:a、
16、定义指针变量temp: LinkList *temp;b、 定义记录文本行数变量j ,每行字符数i ;c、 定义记录文本大写字母数、小写字母数、空格数、数字数和总字数的变量:int WORD=0,word=0,space=0,num=0,sum=0;d、 将指针 temp 指向链表表头: temp=head->next;利用循环对链表中信息进行匹配判断,将大写字母数、小写字母数、空格数、数字数和总字数统计出来:for(j=0;j<=NUM;j+)for(i=0;(i<80)&&(temp->datai)!='#'i+)ch=temp-&g
17、t;datai;if(ch>='A')&&(ch<='Z')WORD+;else if(ch>='a')&&(ch<='z')word+;else if(ch>='0')&&(ch<='9')num+;else if(ch=' ')space+;sum=WORD+word+num;e、 本程序对统计项目设计了菜单。菜单的编写使用while语句进行循环操作。文本内容统计部分到此结束。( 4) Searc
18、hWord() 文章内容查找函数void SearchWord(char *str1,LinkList* temp)char Data20 ;int i,j,k=0,sum=0;int l=1;temp=head->next;strcpy(Data,str1);for(i=0;i<=NUM;i+)for(j=0;j<80;j+)if(temp->dataj)=Datak) k+;else if(Datak!='0')j=j-k;k=0;if(Datak='0')sum+;j=j-k+1;printf(tt第 %d次出现在第%d行第 %d列
19、 n,l,i+1,j);l+;k=0;continue;temp=temp->next;printf(ttt字符串总共出现次数为:%dnn,sum);C=sum;N=i*80+j;说明:a、 定义一个数组,用来记录需要查找的字符内容:char Data20;b、 定义定义文本行数变量j ,每行字符数i ,记录字符出现的次数变量:int i,j,m=0.,sum=0;c、 对形参中定义的指针变量进行操作,使其指向链表表头:temp=head->next;strcpy(Data,str1);: Data 的值赋给 str1使用拷贝函数,将形参中、 de、 利用循环进行查找操作:for(
20、i=0;i<=NUM;i+) /*利用循环进行查找操作*/for(j=0;j<80;j+)if(temp->dataj)=Datak) k+;/*将输入的查找字符与链表中信息比较,找到第一个相同的字符*/else if(Datak!='0')j=j-k;/*从主串第 j-k个位置重新查找 */k=0;if(Datak='0')sum+;/*此字符出现的次数加1*/j=j-k+1;/*j记录下该字符串出现的位置*/printf(tt第%d次出现在第 %d行第 %d列n,l,i+1,j);l+;k=0;continue;temp=temp->
21、next;/*指向下一行 */文本内容查找部分到此结束。( 5) DeleteWord() 文章内容删除函数void DeleteWord(char *str2)char Data20;LinkList *temp,*term;int i,j,a,k,m,y,num;strcpy(Data,str2);for(y=0;y<C;y+)num=80;k=0,m=0;temp=head;for(i=0;i<=NUM;i+)term=temp;temp=temp->next;for(j=0;j<80;j+)if(temp->dataj)=Datak) k+;else if
22、(Datak!='0') j=j-k;k=0;if(Datak='0')num=j;break;if(num<80) break;for(;i<=NUM;i+)for(;j<80;j+)if(j+1<k)term->data80-k+num=temp->dataj+1;else temp->dataj-k+1=temp->dataj+1;term=temp;temp=temp->next;j=0;说明:a、定义一个数组用来存储需要删除的字符或者字符串:char Data20;b、定义指针变量:LinkList
23、 *temp, *term ;c、定义整形变量用来控制行数、字符数:int i,j,k,m,y,num;d、使用拷贝函数讲形参中需要删除的字符或字符串赋值给已定义的数组:strcpy(Data,str2);f 、 使用循环进行删除操作:for(y=0;y<C;y+)num=80;k=0,m=0;temp=head;for(i=0;i<=NUM;i+)/*使用循环进行删除操作*/term=temp;temp=temp->next;for(j=0;j<80;j+)if(temp->dataj)=Datak) k+;else if(Datak!='0')
24、 j=j-k;k=0;if(Datak='0')num=j;break;if(num<80) break;/*首先是使用循环查找到需要删除字符或者字符串的字符数以及字符或者字符串的位置,以便于删除 */for(;i<=NUM;i+)for(;j<80;j+)if(j+1<k)term->data80-k+num=temp->dataj+1;/*删除的字符串不在最后一行,将下一行的字符(由temp 指向)前移到前行 */else temp->dataj-k+1=temp->dataj+1;/*当要删除的字符串在最后一行只要将最后一行
25、的字符前移*/term=temp;temp=temp->next;/*在使用循环,从查找到的字符或者字符串开始进行删除,在一行删除完毕之后,转至下一行进行删除*/j=0;文本内容删除部分到此完成。( 6) Bmenu() 文章内容处理菜单函数void Bmenu(LinkList *temp)char str120;char str220;int t;do/*利用do while循环来控制主菜单显示*/printf();printf(tt*n);printf(t*文章内容处理子菜单*n);t*n);printf(t*1、查找文章中的字符或者字符串*n);printf(t*2、删除文章中的
26、字符或者字符串*n);printf(t*3、显示当前文章内容*n);printf(t*4、返回主菜单*n);printf(t*5、直接退出系统*n);t*n);printf(t请选择 :);scanf(%d,&t);if(t>5)|(t<1)!.n);请回车重新选择 ! 对不起,无此功能printf(tprintf(t);fflush(stdin);getchar();elseswitch(t)case 1:system(cls);printf();printf(tt*n);printf( t*文章内容处理子菜单*n);t*n);printf(ttt请输入您需要查找的字符或
27、字符串:);getchar();gets(str1);printf();SearchWord(str1,temp);printf(tt按回车键继续· ····);getchar();getchar();system(cls);break;case 2:system(cls);printf();printf(tt*n);printf(t*文章内容处理子菜单*n);t*n);printf(ttt请输入您需要删除的字符或字符串:);getchar();gets(str2);printf();SearchWord(str2,temp);DeleteWo
28、rd(str2);printf(tt删除%s后的文章为 :,str2);PrintWord();printf(tt按回车键继续· ····);getchar();getchar();system(cls);break;case 3:system(cls);printf(ntt*n);printf( t*文章内容处理子菜单*n);t*n);PrintWord();printf(ntt按回车键继续· ···· );getchar();getchar();system(cls);break;if(t=
29、4)system(cls);break;if(t=5) exit(0);while(1);说明:用 do-while 语句来制作文章内容处理菜单,用 switch 语句来选择实现功能。( 7) AboutWord() 相关性息void AboutWord() printf( nnnnnnn);*n);printf(*本系统由chevis制作部分功能则是仿照其他程序能力有限*n);printf(*谢谢使用!*n);*n);printf();( 8) menu() 主菜单void menu()int t;LinkList *temp;doprintf();printf();printf();t*n
30、);printf(t*简单的文章编辑器*n);t*n);*n);主菜单 printf(t*t*n);printf(t*1、文章内容输入*n);printf(t*2、显示当前文章内容*n);printf(t*3、文章内容统计子菜单*n);printf(t*4、文章内容处理子菜单*n);printf(t*5、程序相关*n);printf(t*6、退出文章编辑器*n);t*n);printf(t!注:第一次运行本程序时请选择1功能进行输入 !n);t*n);printf( tt请输入相应数字:);scanf(%d,&t);if(t>6)|(t<1)printf(t对不起,无此功能
31、!请回车重新选择!.n);printf(t);fflush(stdin);getchar();elseswitch(t)case 1:system(cls);printf();temp=CreatWord();break;case 2:system(cls);PrintWord();printf();printf();printf(tt按回车键继续· ··· ·);getchar();getchar();system(cls);break;case 3:system(cls);CountWord();break;case 4:system(cl
32、s);Bmenu(temp);break;case 5:system(cls);AboutWord();printf(tt按回车键继续· ··· · );getchar();getchar();system(cls);break;if(t=6) break;while(1);说明:用 do-while 语句来制作文章内容处理菜单,用 switch 语句来选择实现功能。( 9) main() 主函数void main()head=(LinkList *)malloc(sizeof(LinkList);menu();说明:/* 先为 head 申请
33、存储空间,然后创建指针变量temp,然后直接在主菜单函数中进行其他操作*/三、上机调试上机调试过程中遇到的问题及解决方法:a)由于本程序的操作大部分都为经常使用的查找、删除,基本的算法及代码都可以通过查找资料得到,故没有出现多大的问题。错误主要是在于删除等子函数中复杂操作过程中出现的小问题。b)删除及查找过程中需要在子函数中定义一个数组变量,用来存储输入的信息,然后用来与链表中的信息进行比较以达到删除或者查找。另为达到将输入的信息赋值给子函数中定义的数组,特使用了strcpy()函数。c)为了将程序界面更加的完美,做了3 个菜单。清屏函数使用system(“ cls ”),背景字体颜色编写了一个color函数。)一开始编写程序时,在保存、读取这一部分考虑到方便就采用了以节点为单位来存d储。由于文件存储的局限性,以节点存储发生错误。后来采用了单个字符存储和读取来保证文本的保存和读取。e
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年熔化焊接与热切割证考试题库及答案
- 《防鼠疫知识培训》课件
- 《散热器的选择计算》课件
- 类天疱疮的临床护理
- 孕期耳痛的健康宣教
- 孕期肺动脉高压的健康宣教
- 肾盏憩室的临床护理
- 死胎的健康宣教
- 急性化脓性中耳炎的健康宣教
- 恶露的健康宣教
- 耕作学智慧树知到期末考试答案章节答案2024年中国农业大学
- 餐厅实习协议书
- QCT1067.5-2023汽车电线束和电器设备用连接器第5部分:设备连接器(插座)的型式和尺寸
- 2024年度领导干部任前廉政法规知识测试题库150题
- 2024年四川省凉山州中考适应性考试语文试题(含答案解析)
- 人工智能在中药学领域的应用与药物研发创新研究
- 2023-2024学年七年级数学上册举一反三系列专题4.6 动角问题专项训练(40道)(举一反三)(人教版)含解析
- MOOC 房地产管理-华中科技大学 中国大学慕课答案
- 运动训练学完整第五章
- 2024年茶空间运营工作计划
- 食品进销存台账【模板】
评论
0/150
提交评论