课程实践——第三个题——电子词典

2024-04-27 03:38

本文主要是介绍课程实践——第三个题——电子词典,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*
Copyright (c) 2016, 烟台大学计算机学院All rights reserved.
文件名称:first.cpp
作    者:颜丙齐
完成日期:2017年 1 月 6 日
版 本 号:v1.0题目描述电子词典
输入想要查找的词
输出词的释义
样例输入love
样例输出
这是英译汉电子词典!!!
制作人:颜丙齐
指导老师:贺利坚老师
结束程序请输入:0000
请输入您要查找的单词:love
您要找的单词的注释为:v.爱,喜欢;n.爱情
请输入您要查找的单词:0000
*/
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
struct Word
{char English[20];char translate[50];
};//用结构体代表一个单词,描述单词的拼写和注释。
void view();
int  find_word(char *,struct Word *,int );//二分查找函数,有三个参数,第一参数为要查找的单词,第二个参数为查找单词的词典,第三个参数为词典的长度
int open_file(struct Word *);//打开文件
int   find_one_word(struct Word *dictionary,int k);//可以完成查找一个单词的所有功能
int main()
{int k;int r;view();struct Word dictionary[10000];k=open_file(dictionary);do{r=find_one_word(dictionary,k);}while(r>=0);return 0;
}
/*************************************************************
功能描述:输出程序的说明
输入参数:无
返 回 值:无
其他说明:输出几句话,解释该程序
*************************************************************/
void view()
{printf("这是英译汉电子词典!!!\n");printf("制作人:颜丙齐\n");printf("指导老师:贺利坚老师\n");printf("结束程序请输入:0000\n");
}
/*************************************************************
功能描述:完整的进行查找一个单词
输入参数:dictionary-结构体数组的首地址k-结构体的长度
返 回 值:m-用来判断是否结束程序
其他说明:无
*************************************************************/
int   find_one_word(struct Word *dictionary,int k)
{printf("请输入您要查找的单词:");char n[20];scanf("%s",n);int r;//用来接受函数的返回值;int m;r=find_word(n,dictionary,k);int t;t=(n[0]==48)+(n[1]==48)+(n[2]==48)+(n[3]==48);if(t==4){m=-1;}else{if(r<0){printf("对不起,没有查到这个词!!!\n");}else{printf("您要找的单词的注释为:%s\n",dictionary[r].translate);}m=1;}return m;
}
/*************************************************************
功能描述:打开文件,并读入文件数据
输入参数:dictionary-保存文件的结构体
返 回 值:k-结构体数组的长度
其他说明:无
*************************************************************/
int open_file(struct Word *dictionary)
{FILE *fp1;if((fp1=fopen("dictionary.txt","r"))==NULL){printf("不能打开文件!!!\n");exit(1);}int k=0;//计算单词的个数while(!feof(fp1)){fscanf(fp1,"%s%s",dictionary[k].English,dictionary[k].translate);++k;}fclose(fp1);return k;
}
/*************************************************************
功能描述:查找一个单词返回他所在数组的下标
输入参数:dictionary-保存文件的结构体k-结构体数组的长度
返 回 值:index-表明是否查到单词
其他说明:无
*************************************************************/
int  find_word(char *n,struct Word *dictionary,int k)
{int index=-1;int first=0,finall=k-1,middle;while(first<=finall){middle=(first+finall)/2;if(strcmp(n,dictionary[middle].English)==0){index=middle;break;}else if(strcmp(n,dictionary[middle].English)<0)finall=middle-1;elsefirst=middle+1;}return index;
}
学习心得:以前感觉自己学的还可以,可是一到用的时候就发现了,其实还差的远,应该保持一颗平常心,好好做该做的事。

这篇关于课程实践——第三个题——电子词典的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/939424

相关文章

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

Prometheus与Grafana在DevOps中的应用与最佳实践

Prometheus 与 Grafana 在 DevOps 中的应用与最佳实践 随着 DevOps 文化和实践的普及,监控和可视化工具已成为 DevOps 工具链中不可或缺的部分。Prometheus 和 Grafana 是其中最受欢迎的开源监控解决方案之一,它们的结合能够为系统和应用程序提供全面的监控、告警和可视化展示。本篇文章将详细探讨 Prometheus 和 Grafana 在 DevO

springboot整合swagger2之最佳实践

来源:https://blog.lqdev.cn/2018/07/21/springboot/chapter-ten/ Swagger是一款RESTful接口的文档在线自动生成、功能测试功能框架。 一个规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务,加上swagger-ui,可以有很好的呈现。 SpringBoot集成 pom <!--swagge

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

【HarmonyOS】-TaskPool和Worker的对比实践

ArkTS提供了TaskPool与Worker两种多线程并发方案,下面我们将从其工作原理、使用效果对比两种方案的差异,进而选择适用于ArkTS图片编辑场景的并发方案。 TaskPool与Worker工作原理 TaskPool与Worker两种多线程并发能力均是基于 Actor并发模型实现的。Worker主、子线程通过收发消息进行通信;TaskPool基于Worker做了更多场景化的功能封装,例

《数字图像处理(面向新工科的电工电子信息基础课程系列教材)》P98

更改为 差分的数学表达式从泰勒级数展开式可得: 后悔没听廖老师的。 禹晶、肖创柏、廖庆敏《数字图像处理(面向新工科的电工电子信息基础课程系列教材)》 禹晶、肖创柏、廖庆敏《数字图像处理》资源二维码

vue2实践:第一个非正规的自定义组件-动态表单对话框

前言 vue一个很重要的概念就是组件,作为一个没有经历过前几代前端开发的我来说,不太能理解它所带来的“进步”,但是,将它与后端c++、java类比,我感觉,组件就像是这些语言中的类和对象的概念,通过封装好的组件(类),可以通过挂载的方式,非常方便的调用其提供的功能,而不必重新写一遍实现逻辑。 我们常用的element UI就是由饿了么所提供的组件库,但是在项目开发中,我们可能还需要额外地定义一

《C++中的移动构造函数与移动赋值运算符:解锁高效编程的最佳实践》

在 C++的编程世界中,移动构造函数和移动赋值运算符是提升程序性能和效率的重要工具。理解并正确运用它们,可以让我们的代码更加高效、简洁和优雅。 一、引言 随着现代软件系统的日益复杂和对性能要求的不断提高,C++程序员需要不断探索新的技术和方法来优化代码。移动构造函数和移动赋值运算符的出现,为解决资源管理和性能优化问题提供了有力的手段。它们允许我们在不进行不必要的复制操作的情况下,高效地转移资源

Vue3+elementplus实现图片上传下载(最强实践)

图片上传子组件: 实现照片的上传,预览,以及转成以逗号隔开的图片地址,即时监听,并发送消息到父组件。 <!-- ImageUploader.vue --> <template><div><el-upload class="avatar-uploader" :http-request="customUpload" :before-upload="beforeUpload":show-fil