第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

相关文章

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param

FreeRTOS学习笔记(二)任务基础篇

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、 任务的基本内容1.1 任务的基本特点1.2 任务的状态1.3 任务控制块——任务的“身份证” 二、 任务的实现2.1 定义任务函数2.2 创建任务2.3 启动任务调度器2.4 任务的运行与切换2.4.1 利用延时函数2.4.2 利用中断 2.5 任务的通信与同步2.6 任务的删除2.7 任务的通知2

Flink任务重启策略

概述 Flink支持不同的重启策略,以在故障发生时控制作业如何重启集群在启动时会伴随一个默认的重启策略,在没有定义具体重启策略时会使用该默认策略。如果在工作提交时指定了一个重启策略,该策略会覆盖集群的默认策略默认的重启策略可以通过 Flink 的配置文件 flink-conf.yaml 指定。配置参数 restart-strategy 定义了哪个策略被使用。常用的重启策略: 固定间隔 (Fixe

第49课 Scratch入门篇:骇客任务背景特效

骇客任务背景特效 故事背景:   骇客帝国特色背景在黑色中慢慢滚动着! 程序原理:  1 、 角色的设计技巧  2 、克隆体的应用及特效的使用 开始编程   1、使用 黑色的背景: ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/7d74c872f06b4d9fbc88aecee634b074.png#pic_center)   2

AsyncTask 异步任务解析

1:构建AsyncTask 子类的回调方法: A:doInBackground:   必须重写,所有的耗时操作都在这个里面进行; B: onPreExecute:     用户操作数据前的调用; 例如:显示一个进度条 等 ; C: onPostExecute:    当doInBackground 执行完成后;会自动把数据传给onPostExecute方法;也就是说:这个方法是处理返回的数据的方法

16 子组件和父组件之间传值

划重点 子组件 / 父组件 定义组件中:props 的使用组件中:data 的使用(有 return 返回值) ; 区别:Vue中的data (没有返回值);组件方法中 emit 的使用:emit:英文原意是:触发、发射 的意思components :直接在Vue的方法中声明和绑定要使用的组件 小炒肉:温馨可口 <!DOCTYPE html><html lang="en"><head><

react笔记 8-16 JSX语法 定义数据 数据绑定

1、jsx语法 和vue一样  只能有一个根标签 一行代码写法 return <div>hello world</div> 多行代码返回必须加括号 return (<div><div>hello world</div><div>aaaaaaa</div></div>) 2、定义数据 数据绑定 constructor(){super()this.state={na

使用Node-API进行异步任务开发

一、Node-API异步任务机制概述         Node-API异步任务开发主要用于执行耗时操作的场景中使用,以避免阻塞主线程,确保应用程序的性能和响应效率。         1、应用场景: 文件操作:读取大型文件或执行复杂的文件操作时,可以使用异步工作项来避免阻塞主线程。网络请求:当需要进行网络请求并等待响应时,可以使用异步工作项来避免阻塞主线程,从而提高应用程序的响应性能。数据库操

探索Invoke:Python自动化任务的瑞士军刀

文章目录 探索Invoke:Python自动化任务的瑞士军刀背景:为何选择Invoke?`invoke`是什么?如何安装`invoke`?简单的`invoke`库函数使用方法场景应用:`invoke`在实际项目中的使用场景一:自动化测试场景二:代码格式化场景三:部署应用 常见问题与解决方案问题一:命令执行失败问题二:权限不足问题三:并发执行问题 总结 探索Invoke:P

RISC-V (十)任务同步和锁

并发与同步 并发:指多个控制流同时执行。         多处理器多任务。一般在多处理器架构下内存是共享的。           单处理器多任务,通过调度器,一会调度这个任务,一会调度下个任务。  共享一个处                                理器一个内存。                 单处理器任务+中断: 同步: 是为了保证在并发执行的环境中各个控制流可