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

简介: 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565【项目5-电子词典】:做一个简单的电子词典。在文件dictionary.txt中(点此链接下载)作为调试,保存的是英汉对照的一个词典,词汇量近8000个,英文与释义间用’\t’隔开。编程序,将文件中的内容读到两个数组e[]和c[]中,分别代表英文和中文,由用户输入英文

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565


【项目5-电子词典】:做一个简单的电子词典。在文件dictionary.txt中(点此链接下载)作为调试,保存的是英汉对照的一个词典,词汇量近8000个,英文与释义间用’\t’隔开。编程序,将文件中的内容读到两个数组e[]和c[]中,分别代表英文和中文,由用户输入英文词,显示中文意思。运行程序后,支持用户连续地查词典,直到输入“0000”结束,如下图:
      
  提示:文件中的词汇已经排序,故在查找时,用二分查找法提高效率。


参考解答:

#include <fstream>
#include<iostream>
#include<cstdlib>
#include<string>
using namespace std;
string e[8000],c[8000]; //英文和中文数组,要由文件中读入
int wordsNum=0; //词库中实际的词汇条数
int BinSeareh(int low, int high, string k);

int main( )
{
 	string key;      //查询关键词
	//将文件中的数据读入到对象数组中
	ifstream infile("dictionary.txt",ios::in);  //以输入的方式打开文件
	if(!infile)       //测试是否成功打开
	{
		cerr<<"open error!"<<endl;
		exit(1);
	}
	while (infile>>e[wordsNum]>>c[wordsNum])  //读取成功,则重复从文件中读
	{
		++wordsNum;
	}
	infile.close();

	//输入待查关键词并用二分查找法进行查询
	do
	{
		cout<<"请输入要查的词(0000结束):";
		cin>>key;
		if (key=="0000")
			break;
		else
		{
			int low=0,high=wordsNum-1;  //置当前查找区间上、下界的初值
			int index=BinSeareh(low, high, key);
			if (index == -1)
				cout<<"查无此词!"<<endl<<endl;
			else
				cout<<key<<"的中文意思是:"<<c[index]<<endl<<endl;
		}
	}
	while(1);
	cout<<"欢迎再次使用!"<<endl<<endl;
	return 0;
}
//二分查找,结果为所查词在数组中的下标
int BinSeareh(int low, int high, string k)
{
	int mid;
	while(low<=high)
	{
		mid=(low + high) / 2;
		if(e[mid]==k)
		{
			return mid; //查找成功返回
		}
		if(e[mid]>k)
			high=mid-1; //继续在e[low..mid-1]中查找
		else
			low=mid+1; //继续在e[mid+1..high]中查找
	}
	return -1; //当low>high时表示查找区间为空,查找失败
}




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