第16周-任务3-电子词典

2024-03-03 11:38
文章标签 16 任务 电子词典

本文主要是介绍第16周-任务3-电子词典,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【题目】做一个简单的电子词典。

  在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文、中文释义与词性间用’\t’隔开。建一个表示词条的类Words,Words类的一个对象可以描述一个词,类对象数组可以存储词库。将文件中的内容读到对象数组中,由用户输入英文词,显示中文释义。

  提示:文件中的词汇已经排序,故在查找时,用二分查找法提高效率。

  拓展1:允许用户运行程序后,连续地查词典,直到输入”0000”结束。

  拓展2:试着做一个窗口版的电子词典。

  拓展3:使这个词典,读入一篇文章,输出其中的所有名词(或动词,或全部实词)。——搜索引擎用类似的功能,并不是所有词都值得索引。

  <下载相关文件>


【参考解答】

  直接给出拓展1 的参考解答,真正激动人心的是拓展2,那才有个真的电子词典的样子。

#include <fstream>
#include<iostream>
#include<string>
using namespace std;//定义词类
class Word
{
public:void set(string e, string c, string wc);int compare(string);  //英语部分与给定字符串比较,等于返回,大于返回,小于返回-1void display();
private:string english;string chinese;string word_class;
};void Word::set(string e, string c, string wc)
{english=e;chinese=c;word_class=wc;
}void Word::display()
{cout<<english<<'\t'<<word_class<<'\t'<<chinese<<endl<<endl;
}int Word::compare(string k)
{return english.compare(k);
}int BinSeareh(int low, int high, Word *w, string k);int main( )
{Word words[8000]; //用于保存词库string e,c,wc;    string key;      //查询关键词int wordsNum=0;  //词库中词数//将文件中的数据读入到对象数组中ifstream infile("dictionary.txt",ios::in);  //以输入的方式打开文件if(!infile)       //测试是否成功打开{cerr<<"open error!"<<endl;exit(1);}while (!infile.eof()){infile>>e>>c>>wc;words[wordsNum].set(e, c, wc);++wordsNum;}//输入待查关键词并用二分查找法进行查询do{cout<<"请输入待查询的关键词(英文):"<<endl;cin>>key;if (key!="0000"){int low=0,high=wordsNum-1;  //置当前查找区间上、下界的初值int index=BinSeareh(low, high, words, key);if (index == -1)cout<<"查无此词!"<<endl<<endl;elsewords[index].display();}}while(key!="0000");cout<<"欢迎再次使用!"<<endl<<endl;system("pause");return 0;
}int BinSeareh(int low, int high, Word *w, string k)
{int mid;while(low<=high){ mid=(low + high) / 2;if(w[mid].compare(k)==0){return mid; //查找成功返回}if(w[mid].compare(k)>0)high=mid-1; //继续在w[low..mid-1]中查找elselow=mid+1; //继续在w[mid+1..high]中查找}return -1; //当low>high时表示查找区间为空,查找失败
}


【又一参考解答】

  来自pinktinda的专栏 的解答。main()函数很简单,参数传递设计合理,结构非常好。总之,比我的解答好

#include <iostream>
using namespace std;
#include <fstream>
#include <string>
class Word
{
public:void get_cixing(string cixing);void get_chinese(string english);void get_english(string chinese);friend void find_word(Word *t,string word);friend void input_word(Word *t);friend void output_word(Word *t);private:string cixing;string english;string chinese;
};
void Word::get_cixing(string cixing)
{this->cixing = cixing;
}
void Word::get_chinese(string english)
{this->english = english;
}
void Word::get_english(string chinese)
{this->chinese = chinese;
}
void input_word(Word *t)
{string cixing;string english;string chinese;int i;ifstream inFile("dictionary.txt",ios::in);if(!inFile){cerr<<"open error!"<<endl;exit(1);}for(i=0;i<8000;++i){inFile>>chinese;t[i].get_chinese(chinese);inFile>>cixing;t[i].get_cixing(cixing);inFile>>english;t[i].get_english(english);}	inFile.close();}
void output_word(Word *t)
{string cixing;string english;string chinese;ofstream outFile("dic.txt",ios::out);if(!outFile){cerr<<"open dic.txt error!"<<endl;exit(1);}for(int i=0;i<8000;++i){outFile<<t[i].chinese;outFile<<t[i].english;outFile<<t[i].cixing;}		outFile.close();}void find_word(Word *t,string word)
{	int  f=0;int  s=7999;int mid=(f+s)/2;while(f<s&&t[mid].english!=word){if(t[mid].english<word) f=mid+1;if(t[mid].english>word) s=mid-1;mid=f+(s-f)/2;if(t[mid].english==word){cout<<t[mid].chinese<<endl;cout<<t[mid].cixing<<endl;}	}if(t[mid].english!=word)cout<<"没有查到"<<endl;
}
int main()
{Word t[8000];input_word(t);string word;do{cin>>word;find_word(t,word);}while(word!="0000");output_word(t);system("pause");return 0;
}



这篇关于第16周-任务3-电子词典的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

Django之定时任务django-crontab的实现

《Django之定时任务django-crontab的实现》Django可以使用第三方库如django-crontab来实现定时任务的调度,本文主要介绍了Django之定时任务django-cront... 目录crontab安装django-crontab注册应用定时时间格式定时时间示例设置定时任务@符号

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

Spring Boot 集成 Quartz并使用Cron 表达式实现定时任务

《SpringBoot集成Quartz并使用Cron表达式实现定时任务》本篇文章介绍了如何在SpringBoot中集成Quartz进行定时任务调度,并通过Cron表达式控制任务... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启动 Sprin

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J