【题目】做一个简单的电子词典。
在文件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); //英语部分与给定字符串比较,等于返回,大于返回,小于返回-1
void 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;
else
words[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]中查找
else
low=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;
}