OOP版电子词典拓展1

/*
* 程序的版权和版本声明部分
* Copyright (c)2014, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称: fibnacci.cpp
* 作    者:高古尊
* 完成日期:2014年6月5日
* 版本号: v1.0
*
* 输入描述:
* 问题描述:
* 程序输出:
* 问题分析:
*/
#include <iostream>
#include <cstring>
#include <fstream>
using namespace std;
class Word
{
private:
    string english;
    string chinese;
    string word_class;
public:
    void getword(string e,string c,string w)
    {
        english=e,chinese=c,word_class=w;
    }
    void dispaly()
    {
        cout<<english<<'\t'<<chinese<<'\t'<<word_class<<endl;
    }
    bool dengyu(string &w)
    {
        bool f=false;
        if(w==english)
        {
            f=true;
        }
        return f;
    }
    bool dayu(string &w)
    {
        bool f=false;
        if(w>english)
        {
            f=true;
        }
        return f;
    }

};
class Dictionary
{
private:
    int wordsNum;
    Word words[8000];
public:
    Dictionary()
    {
        int i=0;
        string e,c,w;
        ifstream infile("dictionary.txt");
        if(!infile)
        {
            cout<<"打开错误!"<<endl;
        }
        while(infile>>e>>c>>w)
        {
            words[i].getword(e,c,w);
            i++;
        }
        wordsNum=i-1;
    }
    void fin(string w)
    {
        int mi=0,mid=wordsNum/2,ma=wordsNum;
        while(1)
        {
            if(words[mid].dengyu(w))
            {
                words[mid].dispaly();
                break;
            }
            else
            {
                if(words[mid].dayu(w))
                {
                    mi=mid+1;
                    mid=(wordsNum+mi)/2;
                }
                else
                {
                    ma=mid-1;
                    mid=(ma+mi)/2;
                }
            }
            if(mi>ma)
            {
                cout<<"未找到!"<<endl;
                break;
            }
        }
    }
};
int main()
{
    string word;
    Dictionary dictionary;
    ifstream infile("aboutcpp.txt");
    if(!infile)
    {
        cout<<"打开错误!"<<endl;
    }
    while(infile>>word)
    {
        cout<<word<<"--------";
        if((word>"@"&&word<"[")||(word>"`"&&word<"{"))
            dictionary.fin(word);

    }
    return 0;
}

你可能感兴趣的:(类,对象,Class)