Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

Hi ich versuche mich jetzt schon seit Stunden aber ich schaffe es nicht.

Die Aufgabe: Die 200ste Fibonacci Zahl (10 Stellen) herrausfinden. Mein Programm liefert mir aber ab der 185zigsten nur noch 1.#INF.

Wie umgehe ich das Zahlenlimit von float? Liegt es überhaupt daran?

Hier mein Code:

#include <iostream>

using namespace std;

int main (void)

{

float a = 2;

float b = 1;

float old_a = 0;

int counter = 0;

while (counter < 200)

{

cout << "Counter: " << counter+1 << "\t";

cout.precision(10);

cout << a/b << endl;

old_a = a;

a = a + b;

b = old_a;

counter++;

}

return(0);

}

Geschrieben

Die 200. Fibonacci-Zahl ist ungefähr 2.8 * 10^41. Der Wertebereich eines 32-Bit-float geht nur bis 3.4 * 10^38. Außerdem hat so ein float ohnehin nur 7 signifikante Stellen, so dass du damit gar nicht 10 Stellen Genauigkeit erreichen kannst.

Versuch's mal mit double.

Geschrieben (bearbeitet)
warum überhaupt float?

Frag ich mich auch. Mit Double gehts sowohl rekursiv, als auch iterativ:


    double fibIter(int num)

    {

      double result=1;

      double a=1;

      double b=1;


      for(int i=3; i<=num; ++i)

      {

          result=a+b;

          a=b;

          b=result;

      }

      return result;

    }


    double fibRec(int num)

    {

      if(num<=2)

          return 1;

      return fibRec(num-1) + fibRec(num-2);

    }

Bearbeitet von TDM
Geschrieben
Da brauchst du aber schon einen 128-Bit-Integer, wenn du die 200. Fibonacci-Zahl unterbringen willst.

Ja, hatte ich mir auch grad überlegt, siehe Edit - double ist schon besser. ;)

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...