作为一个项目,我从头开始创建一个Rational Class,可以将两个分数作为输入并存储简化的分数。但是,当我尝试输入两个分数时,它似乎隐式使用整数除法,因此我根本无法存储/操作分数。我是否错误地解决了这个问题?错误在哪里?

示例:Rational(3 / 2,9 / 2)返回(1,4)而不是(1/3)。

def gcd(numerator,denominator):
    if numerator < 0:
        absNum = -numerator
    elif denominator < 0:
        absDen = -denominator
    else:
        absNum = numerator
        absDen = denominator

    while absNum != absDen:
        if absNum > absDen:
            absNum = absNum - absDen
        elif absDen >= absNum:
            absDen = absDen - absNum
    return(absNum)


class Rational:
    def __init__(self,numerator=0,denominator=1):
        self.numerator = numerator
        self.denominator = denominator
        if denominator == 0:
            raise ZeroDivisionError("Error: cannot store number with 0 in denominator.")
        elif denominator < 0:
            if numerator < 0:
                self.denominator = -denominator
                self.numerator = -numerator
            else:
                self.numerator = numerator
                self.denominator = -denominator
        if numerator != 0:
            com = gcd(numerator,denominator)
            numerator = numerator/com
            denominator = denominator/com
            self.numerator = numerator
            self.denominator = denominator


Rational(5/3,8/3)


返回(1,2)而不是(5,8)。
编辑:下半部分:我希望能够以(5,8)的结果输入Rational(Rational(5/3),Rational(8/3))。这似乎与上面略有不同。

最佳答案

from __future__ import division


将解决分割问题。

旁注-如果要精确存储有理数,则应确保分子和分母都存储为整数。如果我正确阅读它,则您的gcd函数不适用于浮点数。

要解决此问题,您可能需要执行以下操作:

def __init__(self, num, den):
    num1, den1 = float(num).as_integer_ratio()
    den2, num2 = float(den).as_integer_ratio()
    self.numerator = num1 * num2
    self.denominator = den1 * den2
    ...

关于python - 将分数存储为Rational Python,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/18024403/

10-12 21:42