作为一个项目,我从头开始创建一个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/