• 第十四周(OOP版电子词典)


    /*
    *copyright(c) 2015,烟台大学计算机学院
    *All rights reserved。
    *文件名:第十四周(OOP版电子词典)

    *作者:王忠
    *完毕日期:2015.6.10

    *版本:v1.0
    *
    *问题描写叙述:做一个简单的电子词典。

    在文件dictionary.txt中,保存的是英汉对比的一个词典。词汇量近8000个,英文、中文释义与词性间用’ ’隔开。
    (1)编程序。由用户输入英文词,显示词性和中文释义。


    提示1:假设要用OOP完毕这个词典(当然也能够用OO方法实现),能够定义一个Word类表示一个词条。当中的数据成员string english; 表示英文单词,string chinese;表示相应中文意思,string word_class;表示该词的词性;还能够定义一个Dictionary类。用来表示词典。当中Word words[8000]成员表示词典中的词条。int wordsNum;表示词典中的词条数。在构造函数中从文件读入词条。而专门添加一个成员函数用于查单词。


    提示2:文件里的词汇已经排序,故在查找时。用二分查找法提高效率。
    提示3:这种项目,最好用多文件的形式组织

    *输入描写叙述:

    *程序输出:

    #include <iostream>
    #include <fstream>
    #include <cstdlib>
    #include <string>
    using namespace std;
    class Word
    {
    public:
        void setword(string e,string c,string w);
        string getchinese();
        string getword_class();
        int compare(string );
    private:
        string english;
        string chinese;
        string word_class;
    };
    void Word::setword(string e,string c,string w)
    {
        english=e;
        chinese=c;
        word_class=w;
    }
    string Word::getchinese()
    {
        return chinese;
    }
    string Word::getword_class()
    {
        return word_class;
    }
    int Word::compare(string k)
    {
        return english.compare(k);
    }
    class Dictionary
    {
    public:
        Dictionary();
        int serch(int low,int high,string k);
        void display(string k);
    private:
        Word word[8000];
        int wordNum;
    };
    Dictionary::Dictionary()
    {
        string e,c,w;
        wordNum=0;
        ifstream infile("dictionary.txt",ios::in);
        if(!infile)
        {
            cerr<<"open error";
            exit(1);
        }
        while(!infile.eof())
        {
            infile>>e>>c>>w;
            word[wordNum].setword(e,w,c);
            wordNum++;
        }
        infile.close();
    }
    int Dictionary::serch(int low,int high,string k)
    {
        int mid;
        while(low<=high)
        {
            mid=(low+high)/2;
            if(word[mid].compare(k)==0)
                return mid;
            if(word[mid].compare(k)>0)
                high=mid-1;
            else
                low=mid+1;
        }
        return -1;
    }
    void Dictionary::display(string k)
    {
        int low=0,high=wordNum-1;
        int index=serch(low,high,k);
        if(index>=0)
            cout<<k<<"-->"<<word[index].getword_class()<<"	"<<word[index].getchinese()<<endl;
        else
            cout<<"查无此词"<<endl;
    
    }
    int main()
    {
        Dictionary d;
        string key;
        cout<<"输入英文单词"<<endl;
        while(cin>>key&&key!="0000")
        {
            d.display(key);
        }
        cout<<"好用再来"<<endl;
        return 0;
    }
    
    cout<<k<<"-->"<<word[index].getword_class()<<" "<<word[index].getchinese()<<endl;这一句能够换成    class()+" "<<word  能够直接使用一个+号  这是为什么啊  有什么优点
  • 相关阅读:
    DS博客作业06--图
    DS博客作业05--树
    DS博客作业03--栈和队列
    DS博客作业02--线性表
    DS博客作业03--栈和队列
    DS博客作业02--线性表
    DS博客作业01--日期抽象数据类型设计与实现
    C语言博客作业06--结构体&文件
    C语言博客05--指针
    C语言博客作业04--数组
  • 原文地址:https://www.cnblogs.com/yangykaifa/p/7136647.html
Copyright © 2020-2023  润新知