重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
问题描述
台江ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为成都创新互联公司的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18980820575(备注:SSL证书合作)期待与您的合作!
对于任意给定的单词小助手程序(现有功能可以实现查单词的增删改查、中英、英中测试和分数显示功能),完善其单词查询、错误单词重复记忆和排行功能。
问题分析
首先附上给出的初始代码(已经可以实现基本功能)
#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;i
2>错词重记
错词结构体定义:
//错误单词的结构体 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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。