分数类

#include <iostream>
#include <cmath>
using namespace std;
class CFraction
{
private:
    int nume;  // 分子
    int deno;  // 分母
public:
    CFraction(){nume=0;deno=0;}
    CFraction(int nu,int de):nume(nu),deno(de) {} //使用默认参数的构造函数,并初始化//置值,改变值时用//按照"nu/de"的格式,如"5/2"的形式输入
    void simplify();	 //化简(使分子分母没有公因子)
    CFraction operator*(int &n);
    CFraction operator~();	 //取倒数运算
    friend ostream&operator<<(ostream&,CFraction&);
    friend istream&operator>>(istream&,CFraction&);
    //style为1时,输出化简后形式4/3;
    //style为2时,输出1(1/3)形式,表示一又三分之一;
    //style为3时,用小数形式输出,如1.3333;
    //默认方式0
};
istream&operator>>(istream&in,CFraction&c)
{
    char r;
    in>>c.nume>>r>>c.deno;
    return in;
}
void CFraction::simplify()//化简
{
    int i,t;
    if(nume>deno)
    {
        t=nume;
    }
    else
    {
        t=deno;
    }
    for(i=2; i<sqrt(t); i++)
    {
        while(nume%i==0&&deno%i==0)
        {
            nume/=i;
            deno/=i;
        }
    }
}
CFraction CFraction::operator*(int &n)//扩大n倍
{
    return CFraction(nume*n,deno);
}
CFraction CFraction::operator~()//取倒数
{
    return CFraction(deno,nume);
}
ostream&operator<<(ostream&out,CFraction&c)
{
    out<<c.nume<<"/"<<c.deno;
    return out;
}
int main()
{
    CFraction c1,c2;
    cout<<"输入一个分数(按分子/分母形式):";
    cin>>c1;
    cout<<"输入扩大倍数:";
    int n;
    cin>>n;
    c2=c1*n;
    cout<<"倒数为:";
    c2=~c2;
    cout<<c2;
    c2.simplify();
    cout<<"化简后:"<<c2;
    return 0;
}

运行结果:


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的分数 `Fraction` 的实现: ```python class Fraction: def __init__(self, numerator, denominator=1): if denominator == 0: raise ZeroDivisionError("Denominator cannot be zero.") self.numerator = numerator self.denominator = denominator def __str__(self): return f"{self.numerator}/{self.denominator}" def __repr__(self): return f"Fraction({self.numerator}, {self.denominator})" def __eq__(self, other): if isinstance(other, Fraction): return self.numerator * other.denominator == self.denominator * other.numerator elif isinstance(other, int): return self.numerator == other * self.denominator else: return NotImplemented def __lt__(self, other): if isinstance(other, Fraction): return self.numerator * other.denominator < self.denominator * other.numerator elif isinstance(other, int): return self.numerator < other * self.denominator else: return NotImplemented def __le__(self, other): if isinstance(other, Fraction): return self.numerator * other.denominator <= self.denominator * other.numerator elif isinstance(other, int): return self.numerator <= other * self.denominator else: return NotImplemented def __add__(self, other): if isinstance(other, Fraction): return Fraction(self.numerator * other.denominator + other.numerator * self.denominator, self.denominator * other.denominator) elif isinstance(other, int): return Fraction(self.numerator + other * self.denominator, self.denominator) else: return NotImplemented def __sub__(self, other): if isinstance(other, Fraction): return Fraction(self.numerator * other.denominator - other.numerator * self.denominator, self.denominator * other.denominator) elif isinstance(other, int): return Fraction(self.numerator - other * self.denominator, self.denominator) else: return NotImplemented def __mul__(self, other): if isinstance(other, Fraction): return Fraction(self.numerator * other.numerator, self.denominator * other.denominator) elif isinstance(other, int): return Fraction(self.numerator * other, self.denominator) else: return NotImplemented def __truediv__(self, other): if isinstance(other, Fraction): return Fraction(self.numerator * other.denominator, self.denominator * other.numerator) elif isinstance(other, int): return Fraction(self.numerator, self.denominator * other) else: return NotImplemented ``` 这个支持分数的加、减、乘、除运算,以及比较运算符 `<`, `<=`, `==`。注意到我们在实现运算符方法时,对于可能出现的型不匹配情况,我们返回了 `NotImplemented`,这是为了让 Python 解释器知道我们没有实现这种情况下的运算,从而让它去尝试反向调用运算符方法。例如,如果 `a` 是一个分数,`b` 是一个整数,那么 `a + b` 会先尝试调用 `a.__add__(b)`,如果返回了 `NotImplemented`,则会尝试调用 `b.__radd__(a)`。如果 `b` 也没有实现 `__radd__` 方法,那么就会抛出 `TypeError` 异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值