Fortgesetzte Brüche sind Ausdrücke, die Brüche iterativ beschreiben. Sie können grafisch dargestellt werden:
Oder sie können als Werteliste dargestellt werden: [a0; a1, a2, a3, ... an]
Die Herausforderung:
Nehmen Sie eine Basiszahl: und eine Liste von Nennerwerten: und vereinfachen Sie den fortgesetzten Bruch zu einem vereinfachten rationalen Bruch: Geben Sie Zähler und Nenner getrennt zurück oder drucken Sie sie aus.a0
[a1, a2, a3, ... an]
Beispiele:
√19 : [4;2,1,3,1,2]: 170/39
ℯ: [1;0,1,1,2,1,1]: 19/7
π: [3;7,15,1,292,1]: 104348/33215
ϕ: [1;1,1,1,1,1]: 13/8
Beispielimplementierung: (Python)
def foo(base, sequence):
numerator = 1
denominator = sequence[-1]
for d in sequence[-2::-1]:
temp = denominator
denominator = d * denominator + numerator
numerator = temp
return numerator + base * denominator, denominator
2.002
kann ausgedrückt werden als2002/1000
. Das ist technisch gesehen eine "einzelne Fraktion", Sie möchten wahrscheinlich sagen, "eine einzelne Fraktion in ihrer einfachsten Form".