第五周实验报告 任务2

 
#include <iostream>   
  
using namespace std;  
  
int gcd(int a,int b);//求最大公约数   
  
class CFraction  
  
{private:  
int nume;  // 分子   
  
int deno;  // 分母   
  
public:  
    CFraction(int nu=0,int de=1);   //构造函数,初始化用   
      
    void set(int nu=0,int de=1);    //置值,改变值时用   
      
    void input();//按照"nu/de"的格式,如"5/2"的形式输入   
  
    void simplify();            //化简(使分子分母没有公因子)   
      
    void amplify(int n);            //放大n倍,如2/3放大5倍为10/3   
      
    void output(int style=0);       //输出:以8/6为例,style为0时,输出8/6   
    //style为1时,输出4/3;   
    //style为2时,输出1(1/3),表示一又三分之一;   
    //不给出参数和非1、2,认为是方式0   
};  
int main()  
{  
    CFraction cf;  
  
    cf.set();  
  
    cf.input();  
  
    cf.simplify();  
  
    cf.amplify(4);  
  
    cf.output(2);  
  
    system ("Pause");  
  
    return 0;  
  
}  
  
//构造函数,初始化用   
CFraction::CFraction(int nu,int de)  
{  
    if (de != 0)  
    {  
        nume = nu;  
          
        deno = de;  
    }  
    else  
    {  
        cout << "分母不能为0! " << endl;  
        exit(0);//直接退出   
    }  
      
}   
  
//置值,改变值时用   
void CFraction::set(int nu,int de)  
{  
    if(de != 0)  
    {  
        nume = nu;  
          
        deno = de;  
    }  
}  
void CFraction::input()  
{  
    cout << "请输入分数(m/n):" << endl;  
    int nu,de;  
    while(1)  
    {  
      
        char c;  
          
        cin >> nu >> c >> de;  
          
        if(c != '/')  
        {  
            cout << "输入格式不对!" << endl;  
        }  
        else if(de == 0)  
        {  
            cout << "分母不能为0!" << endl;  
        }  
        else  
            break;  
    }  
    nume = nu;  
  
    deno = de;  
  
}  
  
int gcd(int a, int b)求最大公约数   
{  
    int c;  
      
    while(b != 0)  
    {  
        c = a % b;  
          
        a = b;  
          
        b = c;  
    }  
    return a;  
}  
void CFraction::simplify()  
{  
    int t;  
      
    t = gcd(nume,deno);  
      
    nume = nume / t;  
      
    deno = deno / t;  
      
}  
void CFraction::amplify(int n)放大n倍,如2/3放大5倍为10/3   
{  
    nume = nume * n;  
  
    cout << nume << '/' << deno << endl;  
          
}  
void CFraction::output(int style)  
{  
    int x;  
    switch (style)  
    {  
          
    case 0:  
            cout << nume << '/' << deno << endl;  
              
    case 1:  
              
                x = gcd(nume,deno);  
                  
                cout << nume / x << '/' << deno / x << endl;  
                  
                break;  
              
    case 2:  
              
             x = gcd(nume,deno);  
                  
                nume = nume / x;  
                  
                deno = deno / x;  
                  
                cout << (nume / deno) << '(' << (nume %deno)<< '/' << deno << ')' << endl;  
                  
                break;  
                  
              
    default :  
                cout << nume << '/' << deno << endl;  
                }  
}  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值