第13周項目1—分數類中的運算符重載 (1)



//
*Copyright(c) 2016.煙臺大學計算機與控制工程學院
*ALL rights  reserved.
*文件名稱:main.cpp
 *作者:孫亞茹
*完成日期:2016年5月31日
*問題描述:在分數類中完成分數的加減乘除,再化簡,比較的運算。
*//

#include<iostream>
#include<cmath>
using namespace std;
class CFraction
{
private:
    int nume;  // 分子
    int deno;  // 分母
public:
    CFraction(int num=0,int den=1):nume(num),deno(den) {};
    CFraction operator+(const CFraction &c1);
    CFraction operator-(const CFraction &c1);
    CFraction operator*(const CFraction &c1);
    CFraction operator/(const CFraction &c1);
    friend istream &operator>>(istream &in,CFraction &c1);
    friend ostream &operator<<(ostream &out,CFraction &c1);
    bool operator==(const CFraction &c1);
    bool operator>(const CFraction &c1);
    bool  operator<(const CFraction &c1);
    void huajian();

    //構造函數及運算符重載的函數聲明
};
void CFraction::huajian()
{
    int t,m,n;
    m=deno;
    n=nume;
    while(n!=0)
    {
        t=m%n;
        m=n;
        n=t;
    }
    deno/=m;
    nume/=m;
}
CFraction CFraction::operator+(const CFraction &c1)
{
    CFraction c;
    c.deno=deno*c1.deno;
   c.nume=nume*c1.deno+c1.nume*deno;
    c.huajian();
    return c;
}
CFraction CFraction::operator-(const CFraction &c1)
{
    CFraction c;
    c.deno=deno*c1.deno;
    c.nume=nume*c1.deno-c1.nume*deno;
    c.huajian();
    return c;
}
CFraction CFraction::operator*(const CFraction &c1)
{

    CFraction c;
    c.deno=deno*c1.deno;
    c.nume=nume*c1.nume;
    c.huajian();
    return c;

}

CFraction CFraction::operator/(const CFraction &c1)
{
    CFraction c;
    c.deno=deno*c1.nume;
    c.nume=nume*c1.deno;
    c.huajian();
    return c1;
}
istream &operator>>(istream &in,CFraction &c1)
{
    char ch;
    while(1)
    {
        cin>>c1.nume>>ch>>c1.deno;
        if(c1.deno==0)
            cout<<"分母不能爲0,請重輸"<<endl;
        else if(ch!='/')
            cout<<"格式錯誤,請重輸"<<endl;
        else
            break;
    }
    return cin;
}
ostream &operator<<(ostream &out,CFraction &c1)
{
    cout<<c1.nume<<'/'<<c1.deno;
    return cout;
}
bool CFraction::operator==(const CFraction &c1)
{
    int x,y;
    x=nume*c1.deno;
    y=c1.nume*deno;
    if(x-y==0)
        return true;
    else
        return false;

}
bool CFraction::operator>(const CFraction &c1)
{
    int x,y;
    x=nume*c1.deno;
    y=c1.nume*deno;
    if(x-y>0)
        return true;
    else
        return false;

}
bool CFraction::operator<(const CFraction &c1)
{
    int x,y;
    x=nume*c1.deno;
    y=c1.nume*deno;
    if(x-y<0)
        return true;
    else
        return false;

}
int main()
{
    CFraction c1,c2,c3;
    cout<<"請輸入第一個分數:"<<endl;
    cin>>c1;
    cout<<"請輸入第一個分數:"<<endl;
    cin>>c2;
    cout<<endl;
    cout<<"下面進行計算:"<<endl;
    c3=c1+c2;
    cout<<"c1+c2= "<<c3<<endl;
    c3=c1-c2;
    cout<<"c1-c2= "<<c3<<endl;
    c3=c1*c2;
    cout<<"c1*c2= "<<c3<<endl;
    c3=c1/c2;
    cout<<"c1/c2= "<<c3<<endl;
    cout<<endl;
    cout<<"下面進行比較:"<<endl;
    if(c1>c2)
        cout<<"c1>c2"<<endl;
    if(c1<c2)
        cout<<"c1<c2"<<endl;
    if(c1==c2)
        cout<<"c1=c2"<<endl;
    return 0;
}

心得:

       150多行的代碼終於敲完了,雖然花費了將近2個小時,改了很多次錯誤才能正常運行,但這一切都是值得的。當運行以後出現 0 error 時整個人是興奮的,皇天不負有心人,自己的堅持是正確的。如果當我看到那長達幾頁的錯誤提示時放棄,那我定不會知道這些錯誤的根源或許只是因爲構造函數初始化時沒有給出初始值,也不知道當函數聲明爲引用時應把引用符號放在函數名前面類名後面。而如果當我該錯誤改的不耐煩時放棄,那我將不會知道粗心將一個符號寫錯或許會導致一連串的錯誤,也不會體會到 0 error 的那種滿足感。擁有足夠的耐心才能堅持做下去,而只有堅持下去才能最終取得成功。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章