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

开通VIP
 

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

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

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(一种简单份的英文词典排版系统.doc)为本站上传会员【人****来】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

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

1、 C语言课程设计 院系: 姓名: 学号: 班号: 指导教师: 日期:2007年9月 第一部分 1.设计题目: 一种简单份的英文词典排版系统 2实践目的 通过进行计算机实践,更加系统地理解和掌握C语言的基本概 念、语言特点和编程技巧。利用系统提供的标准函数和自定义函数进 行程序设计,培养利用C语言设计综合程序的能力。 2.要求: (1)能输入和显示打入的词。

2、 (2)能分辨出单词。 (3)对重复的单词和已输入的单词能自动排除。 (4)能按A----Z排序排版。 (5)能将运行结果以文本形式存储。 (6)具有添加新单词并重新排版的能力。 3.分析: 运行结果以文本形式存储,因

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

4、输出,即文件的输出操作。 这四个模块是整体的设计思路,设计核心,整个程序的设计都将围绕这四个模块进行,各个模块都相互衔接,所以需要在设计好各个部分地同时,还要把握好各个部分的连接。 以下这个是简单的设计模块: 英文词典排版系统 单词录入 文件存储 单词浏览 2详细设计 按照上面的整体思路,分别设计各个模块。 单词录入模块要完成输入单词,检查是否重复,排序操作。是设计程序的核心部分,对于检查是否重复,以及排序两个主要方面,我在设计中采用了两个结构体。 文件存储模块把存

5、放单词的词组中的数据写入文件,这个模块还需具有天将新单词的功能。 单词浏览模块完成英文词典的输出,即文件的输出操作。将文件储存模块的内容输出。 [流程图] 输入单词 检查是否重复 删除 No yes no排序操作 文件存储 单词输出 主函数一般设计的简洁,只

6、提供输入,输出,功能处理和输出部分的函数使用。其中各功能模块选择菜单方式。 以下是主要的设计程序: [程序] #define N 1000 char dic[N][20]; void main() { Cheak(); sort(); Work(); } } 该程序以菜单的形式简要反映了主要的设计思路。包含了几个主要模块的核心部分。 3各功能模块设计 1. 单词录入 单词可是字符型,输入时可采用字符型数组; 这是一个重要的模块,包含设计的几个重要部分, 这个模块包含着几个功能,输入单词,检查单词,删除重复的单词,并且对单词进行排序,比较复杂。

7、 流程图如下: 输入单词 检查单词,并排序 由于需要检查是否有多于的单词,而且还要对单词进行排序,所以这个模块需要采用结构体。 (1) 对单词进行排序 输入单词 判断条件 排序 以下的是程序: void Write( int r ) { int i; p = fopen( "Data.txt", "w" );

8、 for( i = 0; i < r; i++ ) { fprintf( p, "%s\n", dic[i] ); } fclose(p); nt sort( ) { int i, j, flag = 1, r; char s[20]; r = Read(); for( i = 1; i < r && flag == 1; i++ ) { flag = 0; for( j = 0; j < r-i; j++ ) {

9、 if( strcmp( dic[j], dic[j+1] ) > 0 ) { flag = 1; strcpy( s, dic[j] ); strcpy( dic[j], dic[j+1] ); strcpy( dic[j+1], s ); } } } Write( r ); return 0; } } 这个结构体采用了strcmp函数,对单词进行比

10、较,从而完成排序。 (2) 检查删除重复的单词 这个模块的流程图如下: 单词 条件 删除重复的单词 以下是这个结构体的设计程序: clear(); for( i = 0; i < r; i++ ) { if( strcmp( d, dic[i] ) == 0 ) { printf( "the word %s has already existed\n",d ); fla

11、g = 1; break; } } if( flag == 0 ) { printf( "the word %s is successfully added\n", d ); strcpy( dic[r], d ); r++; } printf( "\n\ncontinue adding,please input a word;back to main menu,input 0 :\n" ); while( scanf( "%

12、s", f ) && ! ( f[0] == '0' && f[1] == 0 ) ) { flag = 0; for( i = 0; i < r; i++ ) { if( strcmp( f, dic[i] ) == 0 ) { clear(); printf( "the word %s has already existed\n",d ); flag = 1;

13、 break; } } if( flag == 0 ) { clear(); printf( "the word %s is successfully added\n", f ); strcpy( dic[r], f ); r++; } printf( "\n\ncontinue adding,please input a word;back to main

14、menu,input 0 :\n" ); } Write( r ); sort(); clear(); return; } 这个模块同样运用了strcmp函数,通过比较删除重复的单词。 2文件储存模块 这个模块的流程图: 检查排序好的单词 储存单词 将上面整理好的单词以文件的形式储存,而且这个模块能具有被补充新单词的功能。 其设计程序如下: int Read() { int r = 0; p = fopen( "Data.txt", "r" ); while(

15、 fscanf( p, "%s", dic[r] ) != EOF ) { r++; } fclose(p); Write(r); return r; }3.单词浏览 这个模块的流程图,这个模块相对较简单: 储存的文件 输出单词 这个模块的任务就是将出存在文件里的单词输出来,虽然比较简单,是显示最后结果的一步。需将前面的那个个模块的内容输出即可。 以上的几个部分紧密相联,而且每个部分都很重要,相互衔接, 因此每个设计模块都不能忽视。只有每个部分都不出现漏洞,才

16、能完成最后目的。 他的程序是: oid Find( char *s ) { char t[20]; int flag = 0; char f[20]; int r = 0, c, i; int temp; p = fopen( "Data.txt", "r" ); clear(); while( fscanf( p, "%s", t ) != EOF ) { strcpy( dic[r], t ); r++; te

17、mp = strcmp( s, t ); if( temp == 0 ) { c = r; flag = 1; } } Write( r ); if( flag ) { printf( "%s's sequence number is %d!\n", s, c ); } else { printf( "can not find %s!\n", s ); } pri

18、ntf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" ); while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) ) { flag = 0; for( i = 0; i < r; i++ ) { if( strcmp( f, dic[i] ) == 0 ) { flag

19、 1; c = i+1; break; } } if( flag ) { clear(); printf( "%s's sequence number is %d!\n", f, c ); } else { clear(); printf( "can not find %s!\n", f )

20、 } printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" ); } clear(); return; } 第三部分 设计感想: 在老师的带领下进行了C语言程序实践学习。在短短一周的实习期间使我获取了不少新知识也巩固了许多老知识。 C语言是需要有一定基础、而且动手能力强的学科。上机实验是学习程序设计语言必不可少的实践环节,特别是C语言灵活、简洁,更需要通过编程的实践

21、来真正掌握它。对于程序设计语言的学习目的,可以概括为学习语法规定、巩固贯穿系统知识、掌握程序设计方法、提高程序设计能力。 通过多次上机练习,对于语法知识有了感性的认识,加深对它的理解,在理解的基础上就会自然而然地掌握C语言的语法规定。对于一些内容自己认为在课堂上听懂了,但上机实践中会发现原来理解的偏差,更加巩固了学过的知识。 这次上机实习让我学到了很多有用的东西,巩固了之前的学习,让我学到了在教室和做题中学不到的一些知识,通过这个程序的学习,使我进一步理解和运用结构化程序设计的思想和方法。初步掌握开发一个小型实用系统的基本方法,学会调试一个比较长程序的基本方法,学会利用流程图表示算法,进一

22、步掌握和提高利用C语言进行程序设计的能力。 我认为,这次实习对于我是非常有意义的,对我个人的影响比较大,对我的动手能力有了很大的提高。 第四部分 上机操作: 编译、连接和运行 下面是运行后各个模块的界面图: 1 主菜单函数: 2 单词输入功能 3.单词查找 4。查看所有单词 附录: 源程序: #include #include #include #define N 1000 char dic[N][20]; FILE *p; void clear()

23、{ system("cls"); } void Write( int r ) { int i; p = fopen( "Data.txt", "w" ); for( i = 0; i < r; i++ ) { fprintf( p, "%s\n", dic[i] ); } fclose(p); } int Read() { int r = 0; p = fopen( "Data.txt", "r" ); while( fscanf( p, "%s",

24、 dic[r] ) != EOF ) { r++; } fclose(p); Write(r); return r; } void Print() { printf( "\n\n" ); printf( " ********************************************************\n" ); printf( " * way = 1 : append words

25、 *\n" ); printf( " * way = 2 : lookup words *\n" ); printf( " * way = 3 : end work *\n" ); printf( " * way = 4 : cheak *\n" ); printf( " *

26、\n" ); printf( "please choose a way = " ); } int sort( ) { int i, j, flag = 1, r; char s[20]; r = Read(); for( i = 1; i < r && flag == 1; i++ ) { flag = 0; for( j = 0; j < r-i; j++ )

27、 { if( strcmp( dic[j], dic[j+1] ) > 0 ) { flag = 1; strcpy( s, dic[j] ); strcpy( dic[j], dic[j+1] ); strcpy( dic[j+1], s ); } } } Write( r ); return 0; } voi

28、d Cheak() { int r = 0; clear(); p = fopen( "Data.txt", "r" ); while( fscanf( p, "%s", dic[r] ) != EOF ) { printf( "%s ", dic[r] ); r++; } fclose(p); Write(r); if( r == 0 )printf( "there is no word in Data.txt\n" ); else {

29、 printf( "\n\nthere are %d words in Data.txt!\n", r ); } } void Insert( char *d ) { int i; char f[20]; int r = Read(); int flag = 0; clear(); for( i = 0; i < r; i++ ) { if( strcmp( d, dic[i] ) == 0 ) { print

30、f( "the word %s has already existed\n",d ); flag = 1; break; } } if( flag == 0 ) { printf( "the word %s is successfully added\n", d ); strcpy( dic[r], d ); r++; } printf( "\n\ncontinue adding,please input a

31、word;back to main menu,input 0 :\n" ); while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) ) { flag = 0; for( i = 0; i < r; i++ ) { if( strcmp( f, dic[i] ) == 0 ) { clear(); printf( "the word %s ha

32、s already existed\n",d ); flag = 1; break; } } if( flag == 0 ) { clear(); printf( "the word %s is successfully added\n", f ); strcpy( dic[r], f ); r++; } pr

33、intf( "\n\ncontinue adding,please input a word;back to main menu,input 0 :\n" ); } Write( r ); sort(); clear(); return; } void Find( char *s ) { char t[20]; int flag = 0; char f[20]; int r = 0, c, i; int temp; p = fopen( "Data.txt", "r" );

34、 clear(); while( fscanf( p, "%s", t ) != EOF ) { strcpy( dic[r], t ); r++; temp = strcmp( s, t ); if( temp == 0 ) { c = r; flag = 1; } } Write( r ); if( flag ) {

35、 printf( "%s's sequence number is %d!\n", s, c ); } else { printf( "can not find %s!\n", s ); } printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" ); while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) ) { f

36、lag = 0; for( i = 0; i < r; i++ ) { if( strcmp( f, dic[i] ) == 0 ) { flag = 1; c = i+1; break; } } if( flag ) { clear(); printf( "%s's sequ

37、ence number is %d!\n", f, c ); } else { clear(); printf( "can not find %s!\n", f ); } printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" ); } clear(); return; } void Work() {

38、 int i, way; char d[20]; while( 1 ) { Print(); scanf( "%d", &way ); switch( way ) { case 1: printf( "please input a word : " ); scanf( "%s", d ); Insert(d ); brea

39、k; 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(); }

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服