热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

C语言实现单词小助手

这篇文章主要为大家详细介绍了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;ii;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;ii;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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 计算机网络复习:第五章 网络层控制平面
    本文探讨了网络层的控制平面,包括转发和路由选择的基本原理。转发在数据平面上实现,通过配置路由器中的转发表完成;而路由选择则在控制平面上进行,涉及路由器中路由表的配置与更新。此外,文章还介绍了ICMP协议、两种控制平面的实现方法、路由选择算法及其分类等内容。 ... [详细]
  • 本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 探讨一个显示数字的故障计算器,它支持两种操作:将当前数字乘以2或减去1。本文将详细介绍如何用最少的操作次数将初始值X转换为目标值Y。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文探讨如何设计一个安全的加密和验证算法,确保生成的密码具有高随机性和低重复率,并提供相应的验证机制。 ... [详细]
  • 深入解析:手把手教你构建决策树算法
    本文详细介绍了机器学习中广泛应用的决策树算法,通过天气数据集的实例演示了ID3和CART算法的手动推导过程。文章长度约2000字,建议阅读时间5分钟。 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • 在给定的数组中,除了一个数字外,其他所有数字都是相同的。任务是找到这个唯一的不同数字。例如,findUniq([1, 1, 1, 2, 1, 1]) 返回 2,findUniq([0, 0, 0.55, 0, 0]) 返回 0.55。 ... [详细]
  • 本文探讨了卷积神经网络(CNN)中感受野的概念及其与锚框(anchor box)的关系。感受野定义了特征图上每个像素点对应的输入图像区域大小,而锚框则是在每个像素中心生成的多个不同尺寸和宽高比的边界框。两者在目标检测任务中起到关键作用。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 深度学习理论解析与理解
    梯度方向指示函数值增加的方向,由各轴方向的偏导数综合而成,其模长表示函数值变化的速率。本文详细探讨了导数、偏导数、梯度等概念,并结合Softmax函数、卷积神经网络(CNN)中的卷积计算、权值共享及池化操作进行了深入分析。 ... [详细]
author-avatar
Edwin
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有