第五周实验报告(任务三)《处理分数》

本文介绍了一个用于处理分数的C++类,包括分数的输入、输出、化简等功能。通过构造函数、成员函数实现分数的基本操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 /* (程序头部注释开始)

* 程序的版权和版本声明部分

* Copyright (c) 2011, 烟台大学计算机学院学生

* All rights reserved.

* 文件名称:处理分数

* 作 者: 张培培

* 完成日期: 2012年 03月 20日

* 版 本 号:

* 对任务及求解方法的描述部分

* 输入描述:

* 问题描述:

* 程序输出:

* 程序头部的注释结束*/

#include<iostream>  
#include<Cmath>  
using namespace std;  
int gcd(int x,int y );    
class CFraction  
{
private:  
    int nume;  // 分子  
    int deno;  // 分母  
public:  
    CFraction(int nu=0,int de=1);  //构造函数,初始化用  
    void set(int nu,int de);    //置值,改变值时用  
    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  
};  

//构造函数
CFraction::CFraction(int nu,int de)  
{  
    if(de!=0)  
    {  
        nume=nu;  
        deno=de;  
    }  
    else  
    {  
        cout<<"分母不能置为0!"<<endl;  
        exit(0);  
    }
}

//置值
void CFraction::set(int nu=0,int de=1)  
{  
    if(de!=0)  
    {  
        nume=nu;  
        deno=de;  
    }  
}  

//输入函数
void CFraction::input()  
{  
    char c;  
    while(1)  
    {  
        cout<<"输入分数(m/n)";  
        cin>>nume>>c>>deno;  
        if(c!='/')  
            cout<<"格式不对!"<<endl;  
        else if(deno==0)  
			
            cout<<"分母不能为0!"<<endl;  
		
        else   
            break;  
    }    
}  

//化简函数
void CFraction::simplify()  
{  
    int n=gcd(nume,deno);  
    nume=nume/n;  
    deno=deno/n;  
} 

//使函数放大n倍 
void CFraction::amplify(int n)  
{  
    nume*=n;  
}  

void CFraction::output(int style)  
{  
    switch (style)  
    {  
    case 0:  
        cout<<nume<<'/'<<deno<<endl;  
        break;  
    case 1:  
        int i;  
		i=gcd(nume,deno);  
		cout<<(nume/i)<<"("<<")"<<endl;  
		break;  
    case 2:  
        int de,nu;  
        i=gcd(nume,deno);  
        nu=nume/i;  
        de=deno/i;  
    case 3:  
        cout<<nume/double(deno)<<endl;  
        break;  
    default:  
        cout<<nume<<'/'<<deno<<endl;  
    }  
} 


int main()  
{  
    CFraction c1; 
	c1.output(0);
    c1.set(3,4); 
	c1.amplify(5);
    c1.output(0);
	c1.input();
	c1.output(0);
    c1.simplify(); 
	c1.output(0);
    return 0;  
	
} 

//求最大公约数函数
int gcd(int x,int y)  
{  
    int r;  
    while(r!=0)  
    {  
        r=x%y;  
        x=y;  
        y=r;  
    }  
    return x;  
}  

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值