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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

本文(一种简单份的英文词典排版系统.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

一种简单份的英文词典排版系统.docx

1、一种简单份的英文词典排版系统 C语言课程设计院系:姓名:学号:班号:指导教师:日期:2007年9月 第一部分 1.设计题目:一种简单份的英文词典排版系统2实践目的通过进行计算机实践,更加系统地理解和掌握C语言的基本概念、语言特点和编程技巧。利用系统提供的标准函数和自定义函数进行程序设计,培养利用C语言设计综合程序的能力。2.要求: (1)能输入和显示打入的词。 (2)能分辨出单词。 (3)对重复的单词和已输入的单词能自动排除。 (4)能按A-Z排序排版。 (5)能将运行结果以文本形式存储。 (6)具有添加新单词并重新排版的能力。3.分析: 运行结果以文本形式存储,因而要提供文件份额输入输出操作

2、;通过查找操作检查重复单词;提供排序操作实现按A-Z的顺序排版;提供插入操作添加新单词并重新排版。另外通过键盘式菜单实现功能选择。 数据结构采用指针数组或二维数组。以回车键或者空格键作为单词输入结束标志对重复的单词自动排除排除可选第一章的查找方法,数据结构可采用指针和数组。 第二部分1总体设计整个系统被设计为单词录入模块,文件存储模块和单词浏览四个模块。其中单词录入模块要完成输入单词,检查是否重复,排序操作。文件存储模块把存放单词的词组中的数据写入文件。单词浏览模块完成英文词典的输出,即文件的输出操作。 这四个模块是整体的设计思路,设计核心,整个程序的设计都将围绕这四个模块进行,各个模块都相互

3、衔接,所以需要在设计好各个部分地同时,还要把握好各个部分的连接。 以下这个是简单的设计模块:2详细设计 按照上面的整体思路,分别设计各个模块。 单词录入模块要完成输入单词,检查是否重复,排序操作。是设计程序的核心部分,对于检查是否重复,以及排序两个主要方面,我在设计中采用了两个结构体。 文件存储模块把存放单词的词组中的数据写入文件,这个模块还需具有天将新单词的功能。 单词浏览模块完成英文词典的输出,即文件的输出操作。将文件储存模块的内容输出。流程图输入单词检查是否重复排序操作 删除 No yes no 主函数一般设计的简洁,只提供输入,输出,功能处理和输出部分的函数使用。其中各功能模块选择菜单

4、方式。以下是主要的设计程序:程序#define N 1000char dicN20;void main()Cheak();sort();Work(); 该程序以菜单的形式简要反映了主要的设计思路。包含了几个主要模块的核心部分。3各功能模块设计1 单词录入单词可是字符型,输入时可采用字符型数组; 这是一个重要的模块,包含设计的几个重要部分, 这个模块包含着几个功能,输入单词,检查单词,删除重复的单词,并且对单词进行排序,比较复杂。 流程图如下: 由于需要检查是否有多于的单词,而且还要对单词进行排序,所以这个模块需要采用结构体。(1)对单词进行排序 判断条件 以下的是程序:void Write(

5、int r ) int i; p = fopen( Data.txt, w ); for( i = 0; i r; i+ ) fprintf( p, %sn, dici ); fclose(p);nt sort( ) int i, j, flag = 1, r; char s20; r = Read(); for( i = 1; i r & flag = 1; i+ ) flag = 0; for( j = 0; j 0 ) flag = 1; strcpy( s, dicj ); strcpy( dicj, dicj+1 ); strcpy( dicj+1, s ); Write( r );

6、 return 0; 这个结构体采用了strcmp函数,对单词进行比较,从而完成排序。(2)检查删除重复的单词 这个模块的流程图如下: 单词 条件以下是这个结构体的设计程序:clear(); for( i = 0; i r; i+ ) if( strcmp( d, dici ) = 0 ) printf( the word %s has already existedn,d ); flag = 1; break; if( flag = 0 ) printf( the word %s is successfully addedn, d ); strcpy( dicr, d ); r+; prin

7、tf( nncontinue adding,please input a word;back to main menu,input 0 :n ); while( scanf( %s, f ) & ! ( f0 = 0 & f1 = 0 ) ) flag = 0; for( i = 0; i r; i+ ) if( strcmp( f, dici ) = 0 ) clear(); printf( the word %s has already existedn,d ); flag = 1; break; if( flag = 0 ) clear(); printf( the word %s is

8、 successfully addedn, f ); strcpy( dicr, f ); r+; printf( nncontinue adding,please input a word;back to main menu,input 0 :n ); Write( r ); sort(); clear(); return;这个模块同样运用了strcmp函数,通过比较删除重复的单词。2文件储存模块 这个模块的流程图: 将上面整理好的单词以文件的形式储存,而且这个模块能具有被补充新单词的功能。其设计程序如下:int Read() int r = 0; p = fopen( Data.txt,

9、r ); while( fscanf( p, %s, dicr ) != EOF ) r+; fclose(p); Write(r); return r;3.单词浏览这个模块的流程图,这个模块相对较简单:这个模块的任务就是将出存在文件里的单词输出来,虽然比较简单,是显示最后结果的一步。需将前面的那个个模块的内容输出即可。 以上的几个部分紧密相联,而且每个部分都很重要,相互衔接,因此每个设计模块都不能忽视。只有每个部分都不出现漏洞,才能完成最后目的。他的程序是:oid Find( char *s ) char t20; int flag = 0; char f20; int r = 0, c,

10、i; int temp; p = fopen( Data.txt, r ); clear(); while( fscanf( p, %s, t ) != EOF ) strcpy( dicr, t ); r+; temp = strcmp( s, t ); if( temp = 0 ) c = r; flag = 1; Write( r ); if( flag ) printf( %ss sequence number is %d!n, s, c ); else printf( can not find %s!n, s ); printf( nncontinue lookuping,pleas

11、e input a word;back to main menu,input 0 :n ); while( scanf( %s, f ) & ! ( f0 = 0 & f1 = 0 ) ) flag = 0; for( i = 0; i r; i+ ) if( strcmp( f, dici ) = 0 ) flag = 1; c = i+1; break; if( flag ) clear(); printf( %ss sequence number is %d!n, f, c ); else clear(); printf( can not find %s!n, f ); printf(

12、nncontinue lookuping,please input a word;back to main menu,input 0 :n ); clear(); return; 第三部分 设计感想:在老师的带领下进行了C语言程序实践学习。在短短一周的实习期间使我获取了不少新知识也巩固了许多老知识。C语言是需要有一定基础、而且动手能力强的学科。上机实验是学习程序设计语言必不可少的实践环节,特别是C语言灵活、简洁,更需要通过编程的实践来真正掌握它。对于程序设计语言的学习目的,可以概括为学习语法规定、巩固贯穿系统知识、掌握程序设计方法、提高程序设计能力。通过多次上机练习,对于语法知识有了感性的认识

13、,加深对它的理解,在理解的基础上就会自然而然地掌握C语言的语法规定。对于一些内容自己认为在课堂上听懂了,但上机实践中会发现原来理解的偏差,更加巩固了学过的知识。这次上机实习让我学到了很多有用的东西,巩固了之前的学习,让我学到了在教室和做题中学不到的一些知识,通过这个程序的学习,使我进一步理解和运用结构化程序设计的思想和方法。初步掌握开发一个小型实用系统的基本方法,学会调试一个比较长程序的基本方法,学会利用流程图表示算法,进一步掌握和提高利用C语言进行程序设计的能力。我认为,这次实习对于我是非常有意义的,对我个人的影响比较大,对我的动手能力有了很大的提高。 第四部分上机操作:编译、连接和运行下面

14、是运行后各个模块的界面图:1 主菜单函数:2 单词输入功能3单词查找4。查看所有单词附录:源程序:#include#include#include#define N 1000char dicN20;FILE *p;void clear() system(cls);void Write( int r ) int i; p = fopen( Data.txt, w ); for( i = 0; i r; i+ ) fprintf( p, %sn, dici ); fclose(p);int Read() int r = 0; p = fopen( Data.txt, r ); while( fsc

15、anf( p, %s, dicr ) != EOF ) r+; fclose(p); Write(r); return r;void Print() printf( nn ); printf( *n ); printf( * way = 1 : append words *n ); printf( * way = 2 : lookup words *n ); printf( * way = 3 : end work *n ); printf( * way = 4 : cheak *n ); printf( *n ); printf( please choose a way = );int so

16、rt( ) int i, j, flag = 1, r; char s20; r = Read(); for( i = 1; i r & flag = 1; i+ ) flag = 0; for( j = 0; j 0 ) flag = 1; strcpy( s, dicj ); strcpy( dicj, dicj+1 ); strcpy( dicj+1, s ); Write( r ); return 0;void Cheak() int r = 0; clear(); p = fopen( Data.txt, r ); while( fscanf( p, %s, dicr ) != EO

17、F ) printf( %s , dicr ); r+; fclose(p); Write(r); if( r = 0 )printf( there is no word in Data.txtn ); else printf( nnthere are %d words in Data.txt!n, r ); void Insert( char *d ) int i; char f20; int r = Read(); int flag = 0; clear(); for( i = 0; i r; i+ ) if( strcmp( d, dici ) = 0 ) printf( the wor

18、d %s has already existedn,d ); flag = 1; break; if( flag = 0 ) printf( the word %s is successfully addedn, d ); strcpy( dicr, d ); r+; printf( nncontinue adding,please input a word;back to main menu,input 0 :n ); while( scanf( %s, f ) & ! ( f0 = 0 & f1 = 0 ) ) flag = 0; for( i = 0; i r; i+ ) if( str

19、cmp( f, dici ) = 0 ) clear(); printf( the word %s has already existedn,d ); flag = 1; break; if( flag = 0 ) clear(); printf( the word %s is successfully addedn, f ); strcpy( dicr, f ); r+; printf( nncontinue adding,please input a word;back to main menu,input 0 :n ); Write( r ); sort(); clear(); retu

20、rn;void Find( char *s ) char t20; int flag = 0; char f20; int r = 0, c, i; int temp; p = fopen( Data.txt, r ); clear(); while( fscanf( p, %s, t ) != EOF ) strcpy( dicr, t ); r+; temp = strcmp( s, t ); if( temp = 0 ) c = r; flag = 1; Write( r ); if( flag ) printf( %ss sequence number is %d!n, s, c );

21、 else printf( can not find %s!n, s ); printf( nncontinue lookuping,please input a word;back to main menu,input 0 :n ); while( scanf( %s, f ) & ! ( f0 = 0 & f1 = 0 ) ) flag = 0; for( i = 0; i r; i+ ) if( strcmp( f, dici ) = 0 ) flag = 1; c = i+1; break; if( flag ) clear(); printf( %ss sequence number

22、 is %d!n, f, c ); else clear(); printf( can not find %s!n, f ); printf( nncontinue lookuping,please input a word;back to main menu,input 0 :n ); clear(); return;void Work() int i, way; char d20; while( 1 ) Print(); scanf( %d, &way ); switch( way ) case 1: printf( please input a word : ); scanf( %s, d ); Insert(d ); break; case 2: printf( please input a word : ); scanf( %s, d ); Find( d ); break; case 3: printf( all the words are saved in Data.txt ! ); return; case 4: clear(); Cheak(); void main() Cheak(); sort(); Work();

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1