/* *copyright(c) 2015,烟台大学计算机学院 *All rights reserved。 *文件名:第十四周(OOP版电子词典)
*作者:王忠
*完毕日期:2015.6.10*版本:v1.0
* *问题描写叙述:做一个简单的电子词典。在文件dictionary.txt中,保存的是英汉对比的一个词典。词汇量近8000个,英文、中文释义与词性间用’\t’隔开。
(1)编程序。由用户输入英文词,显示词性和中文释义。 提示1:假设要用OOP完毕这个词典(当然也能够用OO方法实现),能够定义一个Word类表示一个词条。当中的数据成员string english; 表示英文单词,string chinese;表示相应中文意思,string word_class;表示该词的词性;还能够定义一个Dictionary类。用来表示词典。当中Word words[8000]成员表示词典中的词条。int wordsNum;表示词典中的词条数。在构造函数中从文件读入词条。而专门添加一个成员函数用于查单词。 提示2:文件里的词汇已经排序,故在查找时。用二分查找法提高效率。 提示3:这种项目,最好用多文件的形式组织*输入描写叙述:
*程序输出:
#include#include #include #include using namespace std;class Word{public: void setword(string e,string c,string w); string getchinese(); string getword_class(); int compare(string );private: string english; string chinese; string word_class;};void Word::setword(string e,string c,string w){ english=e; chinese=c; word_class=w;}string Word::getchinese(){ return chinese;}string Word::getword_class(){ return word_class;}int Word::compare(string k){ return english.compare(k);}class Dictionary{public: Dictionary(); int serch(int low,int high,string k); void display(string k);private: Word word[8000]; int wordNum;};Dictionary::Dictionary(){ string e,c,w; wordNum=0; ifstream infile("dictionary.txt",ios::in); if(!infile) { cerr<<"open error"; exit(1); } while(!infile.eof()) { infile>>e>>c>>w; word[wordNum].setword(e,w,c); wordNum++; } infile.close();}int Dictionary::serch(int low,int high,string k){ int mid; while(low<=high) { mid=(low+high)/2; if(word[mid].compare(k)==0) return mid; if(word[mid].compare(k)>0) high=mid-1; else low=mid+1; } return -1;}void Dictionary::display(string k){ int low=0,high=wordNum-1; int index=serch(low,high,k); if(index>=0) cout< <<"-->"< <<"\t"< < >key&&key!="0000") { d.display(key); } cout<<"好用再来"<
cout<<k<<"-->"<<word[index].getword_class()<<"\t"<<word[index].getchinese()<<endl;这一句能够换成 class()+"\t"<<word 能够直接使用一个+号 这是为什么啊 有什么优点