- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据结构》课程设计报告简单编辑器构造n个城市连接的最小生成树
《数据结构》
课程设计报告
学 号 姓 名 班 级 指导教师
安徽工业大学计算机学院
2012年6月目录 2
题目1:简单的文本编辑器 3
1、问题描述 3
2、设计思路 3
3、数据结构定义 3
4、系统功能模块介绍 4
5、程序清单 4
6、运行及调试分析 14
题目2:构造n个城市连接的最小生成树 17
1、问题描述 17
2、设计思路 17
3、程序清单 18
4、运行及调试分析 26
课程设计总结 27
参考文献 27
题目1:简单的文本编辑器
1、问题描述
编写一个简单的文本编辑软件,能基本实现文本的输入、修改、插入、删除等功能。
2、设计思路
该程序是对一段文本进行简单编辑,存储方式采用链式存储,没有文件操作,故本程序对其文本内容的所有操作都是在链表中进行的。对于文本的输入,采用头插法将文本信息存储到链表已申请好的存储空间中,在此部分设计中最大的问题在于输入文章过程中输入的字符数大于80时如何换行;对于文本内容的统计,使用循环对已存储的文章进行匹配,大写字母数、小写字母数、空格数、数字数直接通过比较即可得到,标点符号通过ASCⅡ比较即可得到;对于文本内容的处理,查找部分仍是使用循环对已存储的文章进行匹配,判断需要查找的字符或者字符串是否与文章中某部分内容相同,如果存在相同的记录相同的个数及位置并输出个数及位置。删除部分先使用程序的查找功能对文章中需要删除的字符或者字符串进行查找,然后对其进行删除。插入部分为通过输入的插入位置(行、列)将字符或者字符串插入到文章制定位置。
3、数据结构定义
数据结构选择:本程序是对输入的文字进行操作,故使用的数据结构为单链表操作。根据第一部分的问题分析有该链表操作有3部分:
Pre Temp Next 另有全局变量*head,作为文章的头指针。
故创建了以下结构体:
typedef struct _list
{ char data[80]; //记录一行字符
int length; //记录一行字符长度
struct _list *next; // 后继指针
struct _list *pre; //前趋指针
int row; //记录整篇文章的行数
}LinkList;
在文章内容创建部分中使用线性表的链式存储,并使用全局变量对文本的各种信息进行存储;
文章的内容统计、删除、查找、插入都采用链表操作完成。
4、系统功能模块介绍
整体框架图:
主要函数说明
CreatWord() 文本输入函数。
PrintWord() 当前文本内容输出函数,将当前存储在链表中的文本内容输出;
CountWord() 文章内容统计函数,对存储在链表中文本内容进行统计,包括对文本内容中的大写字母、小写字母、数字、标点符号、空格以及文章所有字数的个数的统计;
SearchWord() 文章内容查找函数;
DeleteWord() 文章内容删除函数;
InsertWord() 文章内容插入函数;
Dealmenu() 子菜单函数
help() 帮主函数
About() 显示作者信息的函数
menu() 主菜单函数,
main()主函数
5、程序清单
#includestdio.h
#includemalloc.h
#includestring.h
#includeiostream.h
#includestdlib.h
#includeconio.h
#includewindows.h
#define Link_Size 100
int NUM,C,N;
typedef struct list
{
char data[80];
int length;
struct list *next;
struct list *pre;
int row;
} LinkList;
LinkList *head;
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;i80;i++)
temp-data[i]=\0;
printf(开始创建文本,请输入文章(输入#号结束):\n);
for(j=0;jLink_Size;j++)
{
for(i=0;i80;i++)
{
ch=
您可能关注的文档
最近下载
- 《开屏的孔雀》少儿美术PPT绘画课件创意教程教案.pptx VIP
- 四张纸-如何做好优莎纳事业.doc VIP
- sucgodwork天工软件2017 godwork_说明eos操作手册20170821.pdf VIP
- Unit 3 Developing ideas Just A Brother课件--高中英语外研版必修第一册.pptx VIP
- 管道介质色标.doc VIP
- 《室内天麻种植技术》(室内怎样种植天麻).pdf VIP
- 专精特新企业培育计划.docx VIP
- 2025年骨干教师笔试试题及答.docx VIP
- 安全防范系统安装维护员试卷及答案.doc VIP
- 慢性盆腔炎治疗进展及护理.doc VIP
原创力文档


文档评论(0)