ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:141.06KB ,
资源ID:8571926      下载积分:1 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-8571926.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课程设计简单行编辑程序文档格式.docx)为本站会员(b****5)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

数据结构课程设计简单行编辑程序文档格式.docx

1、1)问题描述文本编辑程序是利用计算机进行文字加工的基本软件工具,实现对文本文件的插入、删除等修改操作。限制这些操作以行为单位进行的编辑程序称为行编辑程序。被编辑的文本文件可能很大,全部读入编辑程序的数据空间(内存)的做法既不经济,也不总能实现。一种解决方法是逐段地编辑。任何时刻只把待编辑文件的一段放在内存,称为活区。试按照这种方法实现一个简单的行编辑程序。设文件每行不超过320个字符,很少超过80字符。2)基本要求实现以下4条基本编辑命令:(1) 行插入。格式:i文本将插入活区中第行之后(2)行删除。d删除活区中第行(到第行)。两种格式的例子是:“d10”和“d1014”(3)活区切换。n将活

2、区写入输出文件,并从输入文件中读入下一段,作为新的活区。(4)活区显示。p逐页地(每页20行)显示活区内容,每显示一页之后请用户决定是否继续显示以后各页(如果存在)。印出的每一行要前置以行号和一个空格符,行号固定占4位,增量为1。各条命令中的行号均须在活区中各行行号范围之内,只有插入命令的行号可以等于活区第一行行号减1,表示插入当前屏幕中第一行之前,否则命令参数非法。3)测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据,如首行、尾行。4)实现提示(1) 设活区的大小用行数activemaxlen(可设为100)来描述。考虑到文本文件行长通常为正态分布,且峰值在60到70之间,用3

3、20activemaxlen大小的字符数组实现存储将造成大量浪费。可以以标准行块为单位为各行分配存储,每个标准行块含81个字符。这些行块可以组成一个数组,也可以利用动态链表连接起来。一行文字可能占多个行块。行尾可用一个特殊的ASCII字符(如(012)8)标识。此外,还应记住活区起始行号。行插入将引起随后各行行号的顺序下推。(2) 初始化过程包括:请用户提供输入文件名(空串表示无输入文件)和输出文件名,两者不能相同。然后尽可能多地从输入文件中读入各行,但不超过activemaxlen-x。x的值可以自定。 (3) 在执行行插入命令的过程中,每接收到一行时到要检查活区大小是否已达activema

4、xlen。如果是,则为了在插入这一行之后仍保持活区大小不超过activemaxlen,应将插入点之前的活区部分中第一行输出到输出文件中;若插入点为第一行之前,则只得将新插入的这一行输出。(4) 若输入文件尚未读完,活区切换命令可将原活区中最后几行留在活区顶部,以保持阅读连续性;否则,它意味着结束编辑或开始编辑另一个文件。(5) 可令前三条命令执行后自动调用活区显示。5)选作内容(1) 对于命令格式非法等一切错误作严格检查和适当处理。(2) 加入更复杂的编辑操作,如对某行进行串替换;在活区内进行模式匹配等,格式可以为S串2和m。四、参考文献1王红梅数据结构清华大学出版社2王红梅数据结构学习辅导与

5、实验指导清华大学出版社3严蔚敏,吴伟民数据结构(C语言版)清华大学出版社一、需求分析 程序对文字以行为单位进行编辑,功能有行的插入、行的删除、行的交换和进入下一页。要求用文本文件输入数据,并将修改好的数据保存到另一个文件中。因输入文件可能太大,不能将数据一次性全部输入,仅输入一部分,如:100行。二、问题求解我所编写的软件是行编辑软件,生活中人们常常要对数据进行处理、编辑。但对单个文字的处理效率比较低,人们常常需要更快捷的而编写方法,我这里采用以行为单位进行编辑,。大大提高了处理数据的速度。首先要从文件中将数据读入内存,要以行为单位,而不能以每个字或每句话为单位。因此要定义一个结构体,存储一行

6、的内容。而要使编辑方便,需要每行的编号,因此在结构体中要加入一个存储行号的变量。但从文件中读数据不能一次全读完,因此定义一个活区的类,这个类里包含了行的数量和行的结构体变量。并将之定义为private。要对行进行编辑,而行的数据又是private型的,因此在类里再定义一些操作函数,实现对private数据的操作。接着将文件内容输出到显示器,将活区的内容分次输出,一页10行。下面就是对数据的处理了,每行的内容存储到结构体数组中,删除操作只需将后一个的把前一个覆盖,并将数组数量减一。插入操作,将数组数量加一,从后向前到插入处,把前一个覆盖后一个。然后将要插入的内容写入插入处即可。行与行之间交换,这

7、个比较容易实现。只需将要交换的两行的内容交换即可。三、总体设计程序的功能图:程序流程图 否 是四、详细设计struct Row 行的结构体,包含行的内容,行的编号;class Active 活区的类,包含活区内行的总数量、行的结构体;void putIn ()将文件从文件读入内存;putOut() 将数据输出到显示器del() 对行的删除操作insert() 插入操作chang() 行与行交换五、调试与测试测试删除 测试第一行:输入:d1 正确 测试中间的:d10 正确 测试最后一行 输入: d40 正确测试插入测试第一行:i1 正确i10 正确 i40 正确测试交换: 输入:c2 7 正确测

8、试进入下一页:p 正确测试进入下一个活区;n 正确测试过程中,遇到第一行不显示,程序错误终断,删除后最后一行出现两次等问题。发现是数组越界的问题。文件名不能正确的输入,修改后调用了string类的c-str函数。六、关键源程序清单和执行结果#includestringiomanipfstreamconst int activeMaxLen=50; /活区最大行数const int pageRowNum=10; /每页的行数using namespace std;struct Rowpublic: int num; string content;class Active Active()sumR

9、owNum=activeMaxLen-pageRowNum; void putIn(int numth,string temp) /输入 rnumth.num=numth; rnumth.content=temp; void putOut(int i) /输出 coutri.num ri.content=k+1;i-) ri.content=ri-1.content; sumRowNum+; rk.content=temp; rsumRowNum.num=sumRowNum; void change(int left,int right) /交换 string temp; temp=rleft

10、.content; rleft.content=rright.content; rright.content=temp; int getSumRowNum() /取值 return sumRowNum; void backSumRowNum() /初始化 sumRowNum=activeMaxLen-pageRowNum; string get (int i)return ri.content;private: int sumRowNum; Row ractiveMaxLen+1;void printPage(int page,Active act) /显示页 int i; if(page=1

11、) for(i=page;=pageRowNum; act.putOut(i); else for(i=(page-1)*pageRowNum+1;=page*pageRowNum; if(iact.getSumRowNum() return; int main()/要编辑的文件名的输入请输入要编辑的文件名: string fileName; /文件名beg: cinfileName;fileName.c_str() ifstream infile(fileName.c_str(); if(!infile) cerr找不到该文件!请重新输入文件名 goto beg; ofstream outf

12、ile(out.txt); string temp; char order; int rowth=1; /活区行序号 int page=1; int lrow=0;int rrow=0; int i=1; bool over=0; Active act; while(true) if(!over) rowth=1; page=1; while(rowthorder; switch(order) case d: /删除 dlrow; act.del(lrow); printPage(page,act); break;a /修改 coutrrow; act.change(lrow,rrow);p /显示下一页 if(page=activeMaxLen/pageRowNum) cout这是最后一页!break; page+;n /进入下一个活区 ofstream outfile(,ios:app); for(i=1;=activeMaxLen; outfileact.get(i) if(infile.eof () over=1; cout文件已经输入完毕! act.backSumRowNum(); if(order=) break; /双重跳 return 0;文件名的输入删除操作修改操作插入操作:行与行交换显示下一页显示下一个活区

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2