本篇内容介绍了“C语言怎么实现单词助手程序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、成都网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的桂林网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
问题描述
对于任意给定的单词小助手程序(现有功能可以实现查单词的增删改查、中英、英中测试和分数显示功能),完善其单词查询、错误单词重复记忆和排行功能。
问题分析
首先附上给出的初始代码(已经可以实现基本功能)
#include#include #include #define MAX_CHAR 20 // 最大字符#define MAX_NUM 200 // 单词的最大个数 struct word//单词的结构体{ char en[MAX_CHAR]; // 英文形式 char ch[MAX_CHAR]; //中文形式} s[MAX_NUM]; //单词数组int num; //单词个数int select=1;//select 为是否退出系统的标记int d=0,c=0;//帮助void help(){ printf("\n本系统主要实现英语单词学习的功能。用户可对词典文件中的单词进行预览,增删改查。"); printf("\n同时还可进行中英、英中测试。本系统还提供了测试成绩的显示功能。");} //从文件中读取单词的信息void readfile(){ FILE *fp; int i=0; fp=fopen("data.txt","r"); if(!fp) { printf("\n打开文件data.txt失败!"); } while(fscanf(fp,"%s %s ",s[i].en,s[i].ch)==2) { i++; } num=i; if(0==i) printf("\n文件为空,请选择词典维护增加词条!"); else printf("\n"); fclose(fp); }//从文件中读取单词的信息void writefile(){ FILE *fp; int i=0; fp=fopen("data.txt","w"); if(!fp) { printf("\n打开文件data.txt失败!"); } for(i=0;i i;j--) if(strcmp(s[j-1].en,s[j].en)>0) { strcpy(temp,s[j-1].en); strcpy(s[j-1].en,s[j].en); strcpy(s[j].en,temp); strcpy(temp,s[j-1].ch); strcpy(s[j-1].ch,s[j].ch); strcpy(s[j].ch,temp); } }} //添加单词信息void add(){ int i=num,j,flag=1; while(flag) { flag=0; printf("\n请输入单词的英文形式:"); scanf("%s",s[i].en); for(j=0;j 感兴趣的用户可以自己运行测试
关键算法构造
1>单词查询
由于这里要求在原有程序基础上添加显示同样中文意义,不同的英文单词的功能,因此我将查询函数分设立两个子模块:汉语查询、英语查询以解决显示同样中文意义,不同的英文单词和一词多义的情况。具体思想为:设置一个记录遍历单词数组的下标变量k初值为-1,在每次遍历之前置位-1,遍历的过程中如果遇到一次多译或一意多词的情况就更新下标变量k的值,以此录入多条单词意思,如果遍历结束k仍未-1就没有找到单词。
这里我以中文查询为例:
//查中文 void ChSearch(){ char ch[MAX_CHAR]; //中文形式 int choose=1; int flag; int k=-1;//查询到当前单词的中文下标 while(choose==1) { //查找下一个单词时重置标志变量 k 和 flag k=-1; flag = 1; printf("输入要查询的单词的中文形式:"); scanf("%s",ch); for(int i=0;i2>错词重记
错词结构体定义:
//错误单词的结构体struct wrongWord{ char en[MAX_CHAR]; char ch[MAX_CHAR]; } w[MAX_NUM];//错误单词数组
依照个人理解,这里应该和单词背诵模块大同小异~建立一个错词结构体,把单词背诵过程中的错词记录下来,依次存到错词数组里就好~
3>用户排行
用户信息结构体:
//用户信息结构体typedef struct user{ char name[MAX_CHAR]; int score; }user; user users[MAX_USER];//用户结构体数组user nowuser;
再定义一个用户信息的结构体,规定用户上限,针对不同的用户存储不同的分数,在排行榜里展示~(时间有限,这里还没有实现)
程序源代码
这里仅供参考,因为还有部分功能没有完善......
#include#include #include #include #define MAX_CHAR 20 // 最大字符#define MAX_NUM 200 // 单词的最大个数#define MAX_USER 5 //用户的最大个数 struct word//单词的结构体{ char en[MAX_CHAR]; // 英文形式 char ch[MAX_CHAR]; //中文形式} s[MAX_NUM]; //单词数组 //错误单词的结构体struct wrongWord{ char en[MAX_CHAR]; char ch[MAX_CHAR]; } w[MAX_NUM];//错误单词数组 //用户信息结构体typedef struct user{ char name[MAX_CHAR]; int score; }user; user users[MAX_USER];//用户结构体数组user nowuser; int num;//单词个数int select=1;//select 为是否退出系统的标记int d=0,c=0;//c统计输入错误次数 d统计输入正确次数 //函数声明 void ReciteAllVocabulary();void ReciteWrongVocabulary(); //读文件(单词词库) void ReadVocabularyFile(){ FILE *fp; int i=0; fp=fopen("vocabulary.txt","r"); if(!fp) { printf("\n打开文件vocabulary.txt失败!"); } while(fscanf(fp,"%s %s ",s[i].en,s[i].ch)==2)//? { i++; } num=i; if(i==0) printf("\n哎呀,词库空空如也~,请先选择词典维护增加词条哦!\n"); else printf("\n"); fclose(fp);} //读文件(错词词库) void ReadWrongVocabularyFile(){ FILE *fp; int i = 0; int item= 0; fp = fopen("wrongvocabulary.txt","r"); if(!fp) { printf("\n打开文件wrongVocabulary.txt失败!"); } while(fscanf(fp,"%s %s ",w[i].en,w[i].ch)==2)//? { i++; } num=i; if(i==0) { printf("\n你的错词库当前没有单词~请先选择单词测试查漏补缺哦!\n"); printf("1.单词测试 2.返回上一级 3.退出系统\n"); scanf("%d",&item); switch(item) { case 1: ReciteAllVocabulary(); break; case 2: return; case 3: exit(0); } } else { printf("\n"); } fclose(fp);} //写文件(单词词库) void WriteVocabularyFile(){ FILE *fp; int i=0;//? fp=fopen("vocabulary.txt","w"); if(!fp) { printf("\n打开文件vocabulary.txt失败!"); } for(i=0;i i;j--) if(strcmp(s[j-1].en,s[j].en)>0) { strcpy(temp,s[j-1].en); strcpy(s[j-1].en,s[j].en); strcpy(s[j].en,temp); strcpy(temp,s[j-1].ch); strcpy(s[j-1].ch,s[j].ch); strcpy(s[j].ch,temp); } }} //添加单词信息void Add(){ int i=num,j,flag=1;//num,i为单词总个数 while(flag) { flag=0; printf("\n请输入单词的英文形式:"); scanf("%s",s[i].en); for(j=0;j “C语言怎么实现单词助手程序”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
分享标题:C语言怎么实现单词助手程序
分享地址:http://scgulin.cn/article/jgghoh.html