C语言实现电子英汉词典系统

 更新时间:2022年06月02日 10:04:55   作者:普通学长  
这篇文章主要为大家详细介绍了C语言实现电子英汉词典系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现电子英汉词典系统的具体代码,供大家参考,具体内容如下

一、设计功能(文章仅供参考)

a. 词条录入:即添加单词记录。 
b. 信息显示:将所有的单词按字母顺序显示。 
c. 词条修改:对已经输入的单词信息进行修改。 
d. 词条删除:删除某个单词记录。 
e. 单词查询: 输入单词英文拼写,输出该单词的中文释义。 
f. 信息保存:将单词信息保存到文件。 
g. 退出系统 

二、功能展示

三、思维导图

四、程序源码

#include <stdio.h>    //引入库函数
#include <stdlib.h>
#include <string.h>
#define szWORD 50    //单词长度最大50
#define szSTRN 200    //释义长度最大200
#define szProject sizeof(struct Dictionary)
char fileDict[szSTRN];
typedef struct   Dictionary{
char word[szWORD];
char mean[szSTRN];
} Project ; //定义字典结构体,定义两个字符型变量单词和释义
fpos_t consult(char *word, char *mean)
{
FILE * f = 0; Project  i; 
int r = 0; fpos_t p = 0;
if(!word) return 0;
f = fopen(fileDict, "rb");
if (!f) return 0;
while(!feof(f)) {
  fgetpos(f, &p);
  r = fread(&i, szProject , 1, f);
  if(r < 1) break;
  if(i.word[0] == 0) continue;
  if(strcmp(i.word , word)) continue;
  if(mean) strcpy(mean, i.mean );
  fclose(f);
  return p+1; }
fclose(f);
return 0;}
void Search(void);
void Append(void);
void Delete(void);
void Update(void);
 
int main(int argk, char * argh[])
{
int m= 0;
if(argk>1) 
  strcpy(fileDict, argh[1]);
else
  strcpy(fileDict, "c:\\dict.txt");
for(;;) {
printf("\n\
--------------------\n\
欢迎使用电子英汉词典!\n\
--------------------\n\
1 - 查询词条\n\
2 - 新增词条\n\
3 - 删除词条\n\
4 - 修改词条\n\
5 - 退出词典\n\
--------------------\n");
  m = getchar() - '0';
  switch(m) {
case 1: Search();break;
case 2: Append();break;
case 3: Delete();break;
case 4: Update();break;
default : return 0;}
}
return 0;
}
 
void Search(void)
{
 Project i; fpos_t p = 0;
memset(&i, 0, szProject );
printf("please input the word  you want:"); scanf("%s", i.word );
p = consult(i.word, i.mean );
if(p==0) {
  printf("sorry do not find what you want!\n");
  return;
}
printf("单词:%s\n释义:%s", i.word , i.mean );
}
void Append(void)
{
Project  i; FILE * f = 0; fpos_t p = 0;
memset(&i, 0, szProject );
printf("please input the word you want:"); scanf("%s", i.word );
p = consult(i.word,0);
if(p)     {
  printf("sorry do not find what you want!\n");
  return;
}
printf("please giving the meaning,按确认结束:"); 
fflush(stdin);
gets(i.mean );
f = fopen(fileDict, "ab");
fwrite(&i, szProject , 1, f);
fclose(f);
printf("词条已新增\n");
}
void Delete(void)
{
 Project  i; FILE * f = 0; fpos_t p = 0;
memset(&i, 0, szProject );
printf("please input the word you want:"); scanf("%s", i.word );
p = consult(i.word, 0 );
if(p==0) {
  printf("sorry do not find what you want!\n");
  return;
}
p--;
memset(&i, 0, szProject);
f = fopen(fileDict, "rb+");
fsetpos(f, &p);
fwrite(&i, szProject , 1, f);
fclose(f);
printf("词条已删除\n");
}
void Update(void)
{
 Project  i; FILE * f = 0; fpos_t p = 0; 
memset(&i, 0, szProject );
printf("please input the word you want:"); scanf("%s", i.word );
p = consult(i.word, 0 );
if(p==0) {
  printf("sorry do not find what you want!\n");
  return;
}
p--;
printf("please giving the meaning,按确认结束(输入drop放弃修改):"); 
fflush(stdin);
gets(i.mean );
if(strstr(i.mean ,"drop")) {
  printf("已放弃修改!\n");
  return ;
}
f = fopen(fileDict, "rb+");
fsetpos(f, &p);
fwrite(&i, szProject , 1, f);
fclose(f);
printf("词条已保存\n");
}

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

您可能感兴趣的文章:

相关文章

  • C++示例详解Prim算法与优先队列

    C++示例详解Prim算法与优先队列

    这篇文章介绍了C++ Prim算法、优先队列,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 8皇后问题的解法实例代码

    8皇后问题的解法实例代码

    8皇后问题的解法实例代码,需要的朋友可以参考一下
    2013-03-03
  • c++ 预处理之正整型实现方法

    c++ 预处理之正整型实现方法

    这篇文章主要介绍了c++ 预处理之正整型实现方法,需要的朋友可以参考下
    2017-07-07
  • C语言直接插入排序算法介绍及示例

    C语言直接插入排序算法介绍及示例

    插入排序是把一个记录插入到已排序的有序序列中,使整个序列在插入该记录后仍然有序。插入排序中较简单的种方法是直接插入排序,其插入位置的确定方法是将待插入的记录与有序区中的各记录自右向左依次比较其关键字值的大小
    2022-08-08
  • VC多线程编程详解

    VC多线程编程详解

    这篇文章主要介绍了VC多线程编程,实例形式详细分析了多线程编程的原理与实现方法,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-10-10
  • C++实现保存数据至EXCEL

    C++实现保存数据至EXCEL

    这篇文章主要介绍了C++实现保存数据至EXCEL,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++ JSON库 nlohmann::basic_json::array 的用法示例详解

    C++ JSON库 nlohmann::basic_json::array 的用法示例详解

    nlohmann::json是一个C++的JSON库,它提供了一种容易和直观的方法来处理JSON数据,nlohmann::json::array()是用来创建一个JSON数组的方法,这篇文章主要介绍了C++ JSON库nlohmann::basic_json::array的用法,需要的朋友可以参考下
    2023-06-06
  • C++11正则表达式详解(regex_match、regex_search和regex_replace)

    C++11正则表达式详解(regex_match、regex_search和regex_replace)

    正则表达式(regular expression)是计算机科学中的一个概念,又称规则表达式,下面这篇文章主要介绍了C++11正则表达式(regex_match、regex_search和regex_replace)的相关资料,需要的朋友可以参考下
    2022-09-09
  • VC6.0常见链接错误与解决方法

    VC6.0常见链接错误与解决方法

    这篇文章主要介绍了VC6.0开发中一些常见链接错误的解决方法,需要的朋友可以参考下
    2013-07-07
  • OpenCV实现图像背景虚化效果原理详解

    OpenCV实现图像背景虚化效果原理详解

    相信用过相机的同学都知道虚化特效,这是一种使焦点聚集在拍摄主题上,让背景变得朦胧的效果。本文将详细介绍一些这一效果的实现原理以及代码,需要的可以参考一下
    2022-03-03

最新评论