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类的一个对象可以描述一个词,将文件中的内容读到对象数组中等待查询。由用户输入英文词,显示词性和中文释义。允许连续查词,自行设计退出查词状态的方式。
   提示:文件中的词汇已经排序,故在查找时,用二分查找法提高效率。

参考解答:

#include <fstream>
#include<iostream>
#include<string>
#include<cstdlib>
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<<"请输入待查询的关键词(英文),0000结束:"<<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;
	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时表示查找区间为空,查找失败
}

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

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

  

时间: 2024-07-28 16:55:12

C++第16周项目3 -电子词典的相关文章

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

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

2013-C++第16周项目参考解答链接集

课程主页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目2-指来指去]设计一个程序,利用指针完成下面的工作(1)下面的程序,输入10 100和100 10,均可以输出max=100 min=10,请补充完整程序 #include <iostream> using namespace std; int main( ) { int *p1,*p2,a,b,t; cin>>a>>b; p1=&

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

[题目]做一个简单的电子词典. 在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开.建一个表示词条的类Words,Words类的一个对象可以描述一个词,类对象数组可以存储词库.将文件中的内容读到对象数组中,由用户输入英文词,显示中文释义. 提示:文件中的词汇已经排序,故在查找时,用二分查找法提高效率. 拓展1:允许用户运行程序后,连续地查词典,直到输入"0000"结束. 拓展2:试着做一个窗口版的电子词典. 拓展3

C++第16周项目2——带姓名的成绩单(字符数组版)

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目2-带姓名的成绩单(字符数组版)](参考15周项目3)设score数组中存储同学们的C++成绩,增加一个数组char name[][20]并赋初值,表示同学们的姓名(注意:本周不使用更方便的string类).这两个数组中,同学的姓名与成绩的下标保持一致(例如name[1]和score[1]表示同一位同学的姓名和C++成绩).请(1)输出按成绩排序后的同学的名单:(2

2014秋C++第16周 项目 指针和数组、函数

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目1-数组的排序]按给定部分程序的要求,用指向数组的指针变量作为形式参数编写函数,完成排序.重点体会:(1)排序算法,可以是冒泡,也可以是选择:(2)用指向数组的指针变量作为形式参数,用数组名(即数组的地址)作为实际参数,函数中对于形参的改变实质上也就是对实参对应内存单元的改变:(3)形

2014秋C++第16周 项目1参考 数组的排序

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目1-数组的排序]按给定部分程序的要求,用指向数组的指针变量作为形式参数编写函数,完成排序.重点体会:(1)排序算法,可以是冒泡,也可以是选择:(2)用指向数组的指针变量作为形式参数,用数组名(即数组的地址)作为实际参数,函数中对于形参的改变实质上也就是对实参对应内存单元的改变:(3)形

C++第16周项目5——填空学指针

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目5-填空学指针]采用指针访问方式从键盘给数组a[N]输入数据,然后对元素值重新按逆序存放并输出.请补充完整下面的程序. #include <iostream> using namespace std; const int N=8; int main() { int a[N],*p,*q; for(p=a; p<a+N; p++) ___(1)___; p=a

2014秋C++第16周 项目2参考 用指针玩字符串

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目2-用指针玩字符串] 指针是神奇的,指向整型的指针int *p1,可以操作整型数组int a[]:指向字符型的指针char *p2,可以操作字符数组(字符串)char str[]:更灵活的是,在函数的传递中,指针.数组名在一定程度上可以互换.请编制函数,对字符串的进行各种操作. 序 功

2014秋C++第16周 项目3参考 用函数指针调用函数

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目3-用函数指针调用函数] 将下面的程序补充完整(包括定义函数),使其能够完成图示的功能.请使用已有程序的风格. void eat(); void sleep(); void hitdoudou(); void run(void (*f)()); int main() { int iCh