ImageVerifierCode 换一换
格式:DOC , 页数:16 ,大小:159.22KB ,
资源ID:4138241      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

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

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

开通VIP折扣优惠下载文档

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

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

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


权利声明

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

注意事项

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

一种简单的英文词典排版系统——C语言.doc

1、一种简单的英文词典排版系统 目 录 中文摘要 Ⅰ 主要符号表 Ⅳ 1 题目要求 1 1.1. 1 2 需求分析 3 总体设计 4 详细设计 4.1主函数 4.2各功能模块设计 5.运行结果(附带抓图) 6.总结 参考文献 致谢 主要符号表 #include "stdlib.h" ---为exit()函数提供原型; #include "string.h"---字符串处理函数原型; #include "ctype.h"---字符处理函数原型; #define ROWS 256 #define COLS

2、32---定义“字典”的大小:可存放256个单词,每个单词的长度不超过31 static FILE *fp;---定义文件指针:内部链接,文件作用域; static char a[ROWS][COLS];---定义数组:内部链接,文件作用域;该数组的作用是将文件的内容复制进来,并加以处理。因为处理数组比处理文件方便。 char get_option(void);---接收用户的选项,防止误操作。若输入“a;”(不包括引号),那么将视为选项a int b(int count);---完成选项b的作用--接收新单词; void c(char *pt[], int count);

3、---完成选项c的作用--通过指针对数组排序,实际数组元素位置未改变; int check(char arr[], int count);---对输入的单词进行分辨,若输入 ni hao ,将视为单词 ni ,并且提示并剔除重复的单词; void storage(char *pt[], int count);---在程序结束之前重新排序存储数组中的单词到文件中。 1 题目要求 1. 能输入和显示打入的单词 2. 能分辨出单词 3. 对重复的单词和已经输入的单词能自动排除 4. 能按A—Z的顺序排版 5. 能将运行结果以文本形式存储 6. 具有添加新单词并重新排版的能力

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

5、作。 系统功能模块图: 一种简单的英文词典排版系统 单词浏览 删除单词 添加单词 单词存储 单词排序 单词录入 4 详细设计 1.主函数 【流程图】 显示一系列的功能选项 输入n,判断n是否是1—9 根据n的值调用各功能模块函数 N Y 【程序】 #include "stdio.h" #include "stdlib.h" #include "string.h" #include "c

6、type.h" #define ROWS 256 #define COLS 32 static FILE *fp; static char a[ROWS][COLS]; char get_option(void); int b(int count); void c(char *pt[], int count); int check(char arr[], int count); void storage(char *pt[], int count); int n;    //****n全局变量*****//   char word[N][20]; vo

7、id menu()//***主界面***// { int n,w;//*变量n保存选择菜单数字,w判断输入的数字是否在功能菜单对应数字范围内*// do { puts("\t\t********************MENU********************\n\n"); puts("\t\t\tWelcome to dj's program!\n\n"); puts("\t\t\t\t 1.Add new word."); puts("\t\t\t\t 2.Browse all the words."); puts("\t\t\t\t 3.Se

8、arch the word."); puts("\t\t\t\t 4.Sort the words."); puts("\t\t\t\t 5.Order by A-z."); puts("\t\t\t\t 6.Exit!"); puts("\n\n\t\t****************************************\n"); printf("Choice your number(1-6): [ ]\b\b"); scanf("%d",&n); if(n<1||n>6)//*对选择的数字作判断*// { w=1;

9、 getchar(); } else w=0; }while(w==1); switch(n) { case 1:add();break;//*追加模块*// case 2:browse();break;//*浏览模块*// case 3:search();break;//*查找模块*// case 4:sort();break;//*分类模块*// case 5:order();break;//*排序模块*// case 6:exit(0);//*退出*// } } void main() //********主函数********

10、// { menu(); } 2.公共函数 【程序】 int load()//*加载函数*// { int i,count; int start; char *pt[ROWS]; char ch, len; char input; if((fp=fopen("words.txt","a+"))==NULL)//*以输出打开方式,在此前的记录被覆盖*// { printf("\nCannot open file!\n"); return NULL; } for(i=0;!feof(fp);i++) fscan

11、f(fp,"%s",&word[i]); fclose(fp); return i+1;//*返回记录个数*// } void save(int n)//*保存函数,保存n个记录*// { FILE *fp; int i; if((fp=fopen("words.txt","a+"))==NULL)//*以输出打开方式,在此前的记录被覆盖*// { printf("\nCannot open file!\n"); exit(0); } for(i=0;i

12、fp); } 3.各功能模块设计 1)分类模块 【程序】 void sort() { int i,j,k; char c[20]; if((n=load())==0) { printf("\nCannot open file!\n"); exit(0); } for(i=0;i0) { strcmp(c,word[j]); strcmp(word[j],word[j+1]); s

13、trcmp(word[j+1],c); } save(n); printf("Successful!^_^.\n"); printf("\nNow? 1.browse all 2.back"); scanf("%d",&k); if(k==1) browse(); else if(k==2) menu(); } 2)排序模块 【流程图】 用选择法排序 保 存 返回主菜单 【程序】 void order() //*排

14、序模块*// { int a[N],i,j,t; struct words; n=load(); for(i=0;ia[j]) { t=a[i]; a[i]=a[j]; a[j]=t; } for(j=0;j

15、记录 显示所有记录,让用户看哪个要修改 Y N 显示找到的单词,调用修改函数 提示没有找到 询问用户是 否继续修改 Y 返回主菜单 Y 【程序】 void modify(int a) //*修改模块*// { char c[20]; printf("Enter the new word:"); scanf("%s",c); strcpy(word[a],c); save(n); } 4)删除模块 【流程图】 显示所有记录,让用户看

16、哪个需要删除 输入需要删除的单词 是否找到此单词记录 Y N 提示没有找到 显示找到的记录 调 用 删 除 函 数 询问用户是否继续删除 返回主菜单 Y N 【程序】 void del(int a) //*删除模块*// { int x,i,y; printf("Are you sure to delete this word?\n\t1).sure 2).no and back menu [ ]\b\b"); scanf("%d",&x); //*输入要修改的单

17、词*// if(x==1) { for(i=a;i

18、继续追加单词 保存追加的单词 输入用户要追加的的单词 调用加载函数n=load();并计算可以记录个数n 【流程图】 返回主菜单 Y N 【程序】 void add() //*追加模块*// { int i,x,w1,w2,w; char c[20]; if((n=load())==0) exit(0); else { puts("Enter the new word!\n"); scanf("%s",c); //*输入要追加的单词*// for(i

19、0;i2) w1=1; else

20、 w1=0; }while(w1==1); } else { w2=1; strcpy(word[i],c); save(n+1); printf("Successful!^_^.Now choose what you will do next?\n\t1).add another 2).back menu [ ]\b\b"); do { scanf("%d",&x); if(x<1||x>2) w2=1; else w2=0; }while(w2=

21、1); } switch(x) { case 1:add();break; case 2:menu();break; } } } 6)浏览(全部)模块 返回主菜单 回到分类模块 用户进行选项 显示所有单词记录 【流程图】 【程序】 void browse() //*浏览(全部)模块*// { int i,w; if((n=load())==0) //*加载记录*// { printf("\nCannot open file!\n"); exit(0);

22、 } for(i=0;i

23、 【程序】 void search() //*查找模块*// { int i,x,y; char vs[20]; if((n=load())==0) //*加载记录*// { printf("\nCannot open file!\n"); exit(0); } printf("Enter the word what you want to search!"); scanf("%s",vs); //*输入要查找的单词*// for(i=0;i

24、0) { printf("Successful!^_^.\nThe word is:%s\n",word[i]);//*找到需要修改的单词*// printf("What would you like to do with the word?\n\t1).modify 2).delrte 3).nothing []\b\b"); scanf("%d",&y); if(y==1) modify(i); else {del(i);} } if(i==n) printf("HOHO!Sorry........Not found~~~"); printf("Now...

25、1).one more 2).back 3).exit"); scanf("%d",&x); switch(x) { case 1:search();break; case 2:menu();break; case 3:exit(0); } } 5 运行结果(附带抓图) 主菜单 输入新单词 退出 6总结 通过这次的C语言程序设计实习,我收获了很多。以前的学习是为了应付考试,而此次的实习是将所学的知识运用到实际当中。 该次实习中,我独立完成了这道题。这道题看似繁琐,但思路清晰,就很简单了,指导书中有关文件的题目大同小异,一通则百通。只要讲各功能模块融会贯通并加以适当调整即可,但前提是必须对指导书里的立体熟练掌握。 一年的大学生活让我对计算机理论知识有了一定的了解,但实践出真知,只有吧理论与实践相结合,才能更好地为社会服务。同时也让我了解到了自己的不足,我会继续努力,完善自我。对于学校的精心安排和指导老师的用心辅导非常感谢!!! 16

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

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

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

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

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

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

客服