C语言实现小型电子词典

本文实例为大家分享了C语言实现小型词典系统,供大家参考,具体内容如下

1. 题目描述

用C语言编写一个小型词典,用户可以进行英译汉、汉译英、删除修改单词、添加单词等功能。

2.源代码

/*
  小型词典系统
  版本:0.9
  作者:个快快
  应用模型:文件增删改查
*/
#include <stdio.h>
#include <string.h>
int worsNumber = 0; //单词数目
//----------------------
//定义结构体存储词典数据
//----------------------
typedef struct dic
{
  char word[20];
  char cn[80];
}data;
data dictionnarySql[9000];//词典数据库
//------------
//加载词典数据
//------------
int loadSql(data *sql,char path[100])
{
  int i=0;
  FILE *fp=NULL;
  fp=fopen(path,"r");
  while(fscanf(fp,"%s\t%s",(sql+i)->word,(sql+i)->cn)!=EOF)
  {
    i++;
  }
  fclose(fp);
  printf("共计%d个单词数据\n",i);
  printf("单词加载完毕,请输入指令进行操作:\n");
  return (i); //返回单词数目
}
//------------
//输出用户提示
//------------
void printAction()
{
  printf("-----------------\n");
  printf("1.英译汉\t|\n");
  printf("2.汉译英\t|\n");
  printf("3.添加单词数据\t|\n");
  printf("4.删除单词数据\t|\n");
  printf("5.修正单词数据\t|\n");
  printf("0.退出程序\t|\n");
  printf("-----------------\n");
}
//------------
//指令处理函数
//------------
void dealAction(int action)
{
  if(action==1)
  {
    char word[20];
    int pos;//单词位置
    printf("请您输入要查询的单词:");
    scanf("%s",word);
    pos = searchWord(word);
    if(pos!=-1)
      printf("单词\'%s\'的中文意思是: %s\n",word,dictionnarySql[pos].cn);
    else
      printf("对不起,没有找到您所需要的单词\n");
  }
  else if(action==2)
  {
    int pos;
    char cn[80];
    printf("请您输入汉语词意(关键词即可):");
    scanf("%s",cn);
    pos = searchCn(cn);
    if(pos!=-1)
      printf("该翻译的英语单词是: %s\n",dictionnarySql[pos].word);
    else
      printf("对不起,没有找到您所需要的翻译\n");
  }
  else if(action==3)
  {
    char word[20];
    char cn[80];
    printf("请您输入要补充的单词:");
    scanf("%s",word);
    strcpy(dictionnarySql[worsNumber].word,word);
    printf("请您输入该单词汉语翻译:");
    scanf("%s",cn);
    strcpy(dictionnarySql[worsNumber].cn,cn);
    worsNumber++;
    saveSql();
    printf("补充单词完成\n");

  }
  else if(action==4)
  {
    char word[50];
    int pos;//单词位置
    printf("请输入您要删除的单词:");
    scanf("%s",word);
    pos = searchWord(word);
    if(pos!=-1)
    {
      char a[5] = "#";
      strcpy(dictionnarySql[pos].cn,a);
      strcpy(dictionnarySql[pos].word,a);
      saveSql();
      printf("已经删除该单词\n");
    }
    else
      printf("对不起,没有找到您所需要的单词\n");
  }
  else if(action==5)
  {
    char word[50];
    int pos;//单词位置
    printf("请输入您要修正的单词:");
    scanf("%s",word);
    pos = searchWord(word);
    if(pos!=-1)
    {
      printf("请输入单词汉语翻译:");
      char cn[60];
      scanf("%s",cn);
      strcpy(dictionnarySql[pos].cn,cn);
      saveSql();
      printf("已经修正该单词翻译。\n");
    }
    else
      printf("对不起,没有找到您所需要的单词\n");

  }
}
//------------------------
//返回单词在数据库中的位置
//------------------------
int searchWord(char word[20])
{
  int low, mid, high;
  low = 0;
  high = worsNumber;
  while(low<=high)
  {
    mid = (low+high)/2;
    if(strcmp(dictionnarySql[mid].word,word)>0)
      high = mid-1;
    else if(strcmp(dictionnarySql[mid].word,word)<0)
      low = mid+1;
    else
    {
      return mid;
    }
  }
  //若二分查找查询不到,就执行顺序查找
  int i=0;
  for(i=0;i<worsNumber;i++)
  {
    if(strcmp(dictionnarySql[i].word,word)==0)
      return i;
  }
  return -1;//如果查询不到,就返回负数
}
//------------------------
//返回翻译在数据库中的位置
//------------------------
int searchCn(char cn[80])
{
  //顺序查找
  int i=0;
  for(i=0;i<worsNumber;i++)
  {
    if(strstr(dictionnarySql[i].cn,cn)!=NULL)
      return i;
  }
  return -1;//如果查询不到,就返回负数
}
//--------
//保存数据
//--------
void saveSql()
{
  FILE *fp=NULL;
  fp=fopen("dictionary.txt","w");
  int i=0;
  for(i=0;i<worsNumber;i++)
  {
    if(dictionnarySql[i].word[0]!='#')
    {

      fprintf(fp,"%s\t%s\n",dictionnarySql[i].word,dictionnarySql[i].cn);
    }
  }
  fclose(fp);
}
//----------
//主函数部分
//----------
int main()
{
  worsNumber = loadSql(dictionnarySql,"dictionary.txt"); //加载单词
  int action=-1;//定义动作变量
  while(action!=0)
  {
    printAction();
    scanf("%d",&action);
    dealAction(action);
  }
  return 0;
}

效果:

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

(0)

相关推荐

  • C语言链表实现歌手评分系统

    本文实例为大家分享了C语言链表实现歌手评分系统的具体代码,供大家参考,具体内容如下 此程序可以添加文件操作用于保存歌手得分等信息,此程序实现了链表的增删查和链表冒泡排序交换节点功能 #include <stdio.h> #include <stdlib.h> #include <string.h> //创建结构体及其成员 typedef struct Node { int num;//编号 char name[20];//姓名 float grade[10];//评委评

  • C语言数据结构之迷宫求解问题

    现在网上各种对于迷宫的求解,版本多的数不胜数.本人小白一枚,贴上自己对迷宫的求解这个小项目,自己写的.望能帮助一些同样有困难的人,毕竟我当时费解了好一会儿时间呢. 首先,先标明对于迷宫求解这个项目,首先我提出自己的思路,利用"穷举求解"的方法(严蔚敏老师数据结构一书中提到,一开始不知方法其名.)其实简单来说就是一条路一条路去试,当然不能随便试,我的方法是按照从入口出发,顺一个方向向前探索,走得通就继续向前走:否则留下标记沿原路退回并换一个方向继续探索,直到所有的路都走完为止.还是用栈的

  • C语言清除scanf()缓存的案例讲解

    又重新过一遍C语言,感觉每次重学C语言都有不同的感受,遇到了一个问题,就是scanf()这个问题,其实细究起来,也有很多可以值得深挖的,实际上每次细细的挖掘的话,都是对C语言的更透彻的认识. 那么下面我就对scanf()中清除输入缓冲区的方法讲解: 应用场景:我们使用多个scanf()的时候,如果输入缓冲区还有数据的话,那么scanf()就不会询问用户输入,而是直接就将输入缓冲区的内容拿出来用了,这就导致了前面的错误影响到后面的内容,为了隔离这种问题, 总的思想:通过各种方法将输入缓冲区的内容读

  • C语言实现歌手大奖赛计分程序

    本文实例为大家分享了C语言实现歌手大奖赛计分程序的具体代码,供大家参考,具体内容如下 1. 题目描述 编写一个程序,用户输入评委人数和分数后,程序可以计算去掉一个最高分和最低分后的平均成绩.可多次输入选手成绩,输入N时退出程序. 2. 源代码 #include <stdio.h> #include <stdlib.h> float score[99];//成绩数据 int num=0;//评委数目 float sum=0;//总分 //输入打分数据并输出结果 void inputS

  • C语言实现数据结构迷宫实验

    本文实例为大家分享了C语言实现简单的数据结构迷宫实验,供大家参考,具体内容如下 分析:迷宫实验主要有两部分操作,其一是对迷宫的生成,其二是寻路使用栈的操作. 步骤: 一..h文件 1.首先是迷宫的生成,可以使用随机数种子生成,但主要逻辑部分并不在此,所以在这里直接写死,固定下来. 定义一个坐标类型的结构体,和二维数组迷宫: typedef struct { int x; int y; }Pos; //迷宫类型 typedef struct { int square[10][10] = { {1,

  • C语言实现小学生考试系统

    本文实例为大家分享了C语言实现小学生考试系统的具体代码,供大家参考,具体内容如下 问题及代码: /*烟台大学计算机学院 题目描述:做一个小学生考试系统,功能包括: (1)利用随机数出10道加法题: (2)小学生用户答题给出每道题的答案: (3)对小学生的答题进行评判: (4)计算出小学生答题正确率. 作者:景怡乐 完成时间:2016年12月29日 */ #include <stdio.h> #include <stdlib.h> #include <time.h> in

  • C语言实现小学生随机出题测试计分

    本文实例为大家分享了C语言实现随机出题测试计分的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <stdlib.h> #include <time.h> int test(); int checknum(int a, int b); int checkresult(int x); int a = -1, b, c, x; static int k = 0, grade; void main() { printf("请

  • C语言实现小学生计算机辅助教学系统

    开发一个小学生计算机辅助教学系统.使用随机书产生函数产生1~10之间的随机数作为操作数,随机产生一道四则运算题,配合使用switch语句和print()函数调用,来为学生输入的正确或者错误的答案输出不同的评价.若10道题做完之后正确率低于75%,则重新做10道题,直到回答正确率高于75%时才退出程序.要求用模块化程序设计方法来编程. #include<stdio.h> #include<stdlib.h> #include<time.h> int Calculate(i

  • C语言数据结构之迷宫问题

    本文实例为大家分享了数据结构c语言版迷宫问题栈实现的具体代码,供大家参考,具体内容如下 程序主要参考自严蔚敏老师的数据结构c语言版,在书中程序的大体框架下进行了完善.关于迷宫问题的思路可查阅原书. #include<iostream> using namespace std; #define MAXSIZE 10 typedef int Status; typedef struct{ int x; int y; }Postype; typedef struct{ int ord; Postyp

  • C语言实现无规律数据加密、解密功能

    在网络传输重要信息或存储重要文件信息时,大部分会对数据加密,保证数据的安全性.互联网上流行的可逆加密方式对数据的安全性没有保证,便自己写了一套安全性极高加密.解密方法. 方法的实现方式及特点: 1.采用指定单个字节加密转换(转换形式为ascll码表中0-128的形式,由1个字节拆分为三个字节,下面说明拆分方式): 2.采用数组中随机数据减指定加密字节(比如当前数据ascll码为121,当前数组中的数据为222,结果为222-121=101,当然这个只是参考实例): 3.采用随机指定数组方式(如果

随机推荐