第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);  //英语部分与给定字符串比较,等于返回,大于返回,小于返回-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;
}
时间: 2024-08-01 20:38:44

第16周-任务3-电子词典的相关文章

C++第16周项目3 -电子词典

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/9078413 [项目3]电子词典 做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开.建一个表示词条的类Word,Word类的一个对象可以描述一个词,将文件中的内容读到

C++第15周项目5——-电子词典

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目5-电子词典]:做一个简单的电子词典.在文件dictionary.txt中(点此链接下载)作为调试,保存的是英汉对照的一个词典,词汇量近8000个,英文与释义间用'\t'隔开.编程序,将文件中的内容读到两个数组e[]和c[]中,分别代表英文和中文,由用户输入英文词,显示中文意思.运行程序后,支持用户连续地查词典,直到输入"0000"结束,如下图:     

2014秋C++第17周 项目7参考 电子词典结构体版

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目7-电子词典结构体版]做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开.编程序,由用户输入英文词,显示词性和中文释义.提示1:定义一个Word结构体表示一个词条,其中的数据成员string

C++第15周(春)项目3 - OOP版电子词典(一)

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序中需要的相关文件,请到http://pan.baidu.com/s/1qW59HTi下载.) 做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开. 编程序,由用户输入英文词,显示词性和中文释义. 提示1:如果要用OO

C++第15周(春)项目3 - OOP版电子词典(二)

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序需要的相关文件,请到http://pan.baidu.com/s/1qW59HTi下载.) 做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开. 编程序,由用户输入英文词,显示词性和中文释义. 提示1:如果要用OOP

2014秋C++第14周项目4参考-电子词典

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目4-电子词典]做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文与释义间用'\t'隔开.编程序,将文件中的内容读到两个数组e[]和c[]中,分别代表英文和中文,由用户输入英文词,显示中文意思.运行程序后,支持用户连续地查词典

c-用C编写一个电子词典。。。

问题描述 用C编写一个电子词典... 学习了几周嵌入式系统开发的课程,现在正在学C课程,然后有一个阶段性项目,要求编写一个电子词典.自学者,真的不知道该如何先下手!求教各位啦:怎么下手? 解决方案 这个拿度比较大呢,要好好考录一下 解决方案二: 开发的怎样了,这个好像要数据库的吧,学习中.... 解决方案三: 先做好数据文本,然后就是数据查找了!!嵌入式的话,你可以用.h 文件来保存数据..

2015级C++第16周实践项目 文件

本周项目中用到的数据文件,请在此下载点这儿-. [项目1 - 小玩文件]参考解答 (1)下面程序的功能是统计文本文件abc.txt中的字符个数,请填空将程序补充完整. #include <iostream> #include <cstdlib> #include _____________ // (1) using namespace std; int main() { fstream file; file.open("abc.txt", _________);

C++程序设计课程师生互动(2012年春第16周)

4班有为数不少的同学已经习惯了不提交任何作品,包括曾经的博文明星. 也许更难了.但这个可能我懂,难不难,要看做不做.不做,永远难:坚持做,没有难的.很多认真学习的同学也告诉我,这不是关键. 也许更忙了.是的,本周的学生活动多.大学生是要投入课外活动的.只是,要补上在知识学习方面的遗漏.多头兼顾,这是大学生应有的生活,会收获很多,然而如果由此放弃核心利益,那就不明智了. 也许是有其他更重要的事,只是有些事让我担忧.不知相关同学是否也忧.可以忧而出位,朝向不忧走去:也有忧而更忧,继续在圈子里打转.