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

简介: 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/9078413【项目3】电子词典   做一个简单的电子词典。在文件dictionary.txt中,保存的是英汉对照的一个词典,词汇量近8000个,英文、中文释

课程首页地址: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(选做):试着做一个窗口版的电子词典。


  

目录
相关文章
WK
|
10天前
|
机器学习/深度学习 人工智能 算法
那C++适合开发哪些项目
C++ 是一种功能强大、应用广泛的编程语言,适合开发多种类型的项目。它在游戏开发、操作系统、嵌入式系统、科学计算、金融、图形图像处理、数据库管理、网络通信、人工智能、虚拟现实、航空航天等领域都有广泛应用。C++ 以其高性能、内存管理和跨平台兼容性等优势,成为众多开发者的选择。
WK
32 1
|
28天前
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
234 3
|
2月前
|
C++
【C++案例】一个项目掌握C++基础-通讯录管理系统
这篇文章通过一个通讯录管理系统的C++项目案例,详细介绍了如何使用C++实现添加、显示、删除、查找、修改和清空联系人等功能。
39 3
|
4月前
|
Rust 测试技术 编译器
Rust与C++的区别及使用问题之Rust项目中组织目录结构的问题如何解决
Rust与C++的区别及使用问题之Rust项目中组织目录结构的问题如何解决
|
3月前
|
编译器 C++ 开发者
Visual Studio属性表:在新项目中加入已配置好的C++库
通过以上步骤可以确保Visual Studio中新项目成功地加入了之前已配置好的C++库。这个过程帮助开发者有效地管理多个项目中共享的库文件,提升开发效率。
81 0
|
4月前
|
Java C++ 开发者
如何根据项目需求选择使用C++还是Python进行内存管理?
【7月更文挑战第2天】如何根据项目需求选择使用C++还是Python进行内存管理?
47 0
|
6月前
|
存储 C++ UED
【C++】飞机大战项目记录
通过上面的设计,我们实现来看飞机大战的主要功能
89 4
|
6月前
|
存储 安全 测试技术
【C++】string学习 — 手搓string类项目
C++ 的 string 类是 C++ 标准库中提供的一个用于处理字符串的类。它在 C++ 的历史中扮演了重要的角色,为字符串处理提供了更加方便、高效的方法。
59 0
【C++】string学习 — 手搓string类项目
|
6月前
|
C++
C++入门项目——通讯管理系统
C++入门项目——通讯管理系统
|
6月前
|
设计模式 存储 算法
C++从入门到精通:3.7阅读和理解开源项目——在实际项目中应用C++编程技巧和规范
C++从入门到精通:3.7阅读和理解开源项目——在实际项目中应用C++编程技巧和规范
123 0
下一篇
无影云桌面