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

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

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按