Fibonacci Zahlen

criminal

Mitglied
Hallo an alle,

habe eine Frage und komme echt nicht zurecht:

ich muss Fibonacci Zahlen berechnen, anfangs klein und später größer


Habe folgenden Code gefunden und genutzt

Code:
Zahl fib()
	{
		StringBuilder rueckgabe = new StringBuilder();
		int zahl = Integer.parseInt(umwandlung);
		
		int a = 0;
		int b = 1;
		int c = 1;
		for(int i = 0; i < zahl; i++) 
		{
			c = a + b;
			a = b;
			b = c;
		}
		rueckgabe.insert(0, c);
		return new GrosseZahl(rueckgabe.toString());
	}


meine Frage ist jetzt:

Das klappt eigentlich hervorragend, aber z.B. bei der zahl 100 erwartet das Testprogramm: 573147844013817084101


wo liegt jetzt mein Fehler??

Es geht nur um die Berechung.


Danke im vorraus
 

AquaBall

Top Contributor
Da Problem ist, dass nicht nur die Rückgabe eine "großeZahl" werden kann, sondern schon viel früher die Berechnungsvariablen a,b,c.

Schon bei 24 kommst du über die Short-Grenze. Und dann geht's weiter exponentiell . Das würde ein wenig Probieren bei der Fehlersuche schon ergeben.

Die musst du auch als große Zahl führen.
 
Zuletzt bearbeitet:

Kevin94

Top Contributor
Du verwendest int zum berechnen. Die größte von einem int repräsentierbare Zahl ist 2^31-1=2 147 483 647 und das ist deutlich kleiner als dein erwarteter Wert, du must also intern (und wahrscheinlich auch in GrosseZahl) einen größeren Datentyp nehmen, z.B. long (das reicht gerade noch, wenn ich mich nicht verzählt habe) oder eben BigInteger.
 

criminal

Mitglied
Problem ist BigInteger ist durch die Aufgabe verboten und die nächste Zahl wäre noch größer deshalb fällt long auch flach.

Gut, dann habe ich also schon viel früher ein Problem, mist :(
 

AquaBall

Top Contributor
Vielleicht ist das der Sinn der Aufgabe, dass du eine StringAdditions-Algorithmus programmierst.
Ist ganz interessant, und gar nicht so schwer. (wenn du nicht totaler Anfänger bist)
 

Kevin94

Top Contributor
Du könntest double nehmen, dann ist das Ergebnis aber nichtmehr genau. Die einzige andere Alternative, wenn BigInteger und andere Klassen aus anderen Bibliotheken verboten sind, sich diese selbst zu Programmieren. Da du nur Addition brauchst, wird das nicht ganzsoviel Aufwand, kannst ja mal schauen wie BigInteger intern seine Daten speichert.

[EDIT]Das mit dem speichern als String und dann sozusagen "schriftliche Addition" nachzuprogrammieren wäre mir jetzt als worst-case für eine Selbstimplementation auch einefallen, wollte das aber nicht mit ins Gespräch bringen.[/EDIT]
 
Zuletzt bearbeitet:

AquaBall

Top Contributor
Du könntest double nehmen, dann ist das Ergebnis aber nichtmehr genau.

FibonacciZahlen die
Code:
nichtmehr genau
sind, sind halt nicht sehr prickelnd.
Außerdem ist hier auch hier nur eine Frage der Zeit bis die Grenzen erreicht sind.

Ich habs nun mal (spaßhalber) ausprogrammiert.
Mein Ergebnis für 1000. Fibonacci hat 207 Stellen:
35341000917875257533994483352045906828494504635815
49776041091752538906966342713601215835661100647255
10836075851584985143412396868586425109102723291106
57061875007539271063332172999210674332164028135679
4177320

Damit du's nicht einfach 1zu1 kopierst hab ich im Code 2-3 Fehler eingebaut!
Java:
public class StringAdd {
	public static void main(String[] args) {
		StringAdd sa=new StringAdd();
		String a="1";
		String b="1";
		for (int i=0 ;i<1000; i++) {
			String c= sa.stringAdd(a,b);
			b=c;
		}
		System.out.println("1000. Fibonacci hat "+b.length()+" Stellen:");
		System.out.println(b);
	}
	
	String stringAdd(String a, String b) {
		int maxA =a.length();
		int maxB =b.length();
		String neu="", ausgleich="";
		
		// Sicherstellen, dass Zahlen gleich lang sind
		int diff=Math.abs(maxA-maxB);
		for ( ; diff>0; diff--) {	// Füllstring erzeugen
			ausgleich += "0";
		}
		
		if (maxA>maxB) {		// Strings gleich lang machen
			b=ausgleich+b;
		} else {
			a=ausgleich+a;
			maxA =a.length();
		}
		
		int uebertrag=0;
		for (int idx=maxA-1; idx>=0; idx--){
			int zifferA=a.charAt(idx)-'0';
			int zifferB=b.charAt(idx)-'0';
			int pos=zifferA+zifferB + uebertrag;
			uebertrag=0;
			if (pos>9) {
				pos+=10;
				uebertrag=1;
			}
			neu = pos+neu;
		}
		if (uebertrag>0) {
			neu = "1"+neu;
		}
		return neu;
	}
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
jhCDtGVjcZGcfzug Fibonacci Zahlen rekursiv und iterativ Java Basics - Anfänger-Themen 21
B Fibonacci Zahlen dynamische Programmierung Java Basics - Anfänger-Themen 7
S Fibonacci Zahlen rekursiv Java Basics - Anfänger-Themen 1
A Fibonacci Zahlen Java Basics - Anfänger-Themen 1
K Fibonacci Zahlen Java Basics - Anfänger-Themen 3
B Fibonacci Zahlen rekursiv Array Java Basics - Anfänger-Themen 12
J Fibonacci Zahlen berechnen Java Basics - Anfänger-Themen 3
J Ausgabe der fibonacci Zahlen Java Basics - Anfänger-Themen 4
0 Fibonacci Zahlen seeeehr schnell berechnen Java Basics - Anfänger-Themen 9
K Fibonacci Zahlen Java Basics - Anfänger-Themen 2
K Programmieren von den ersten 70 Fibonacci-Zahlen Java Basics - Anfänger-Themen 2
G Iterativer Algorithmus zur Berechnung der Fibonacci Zahlen Java Basics - Anfänger-Themen 1
P Fibonacci-Zahlen Java Basics - Anfänger-Themen 6
S Abwandlung der Fibonacci Folge Java Basics - Anfänger-Themen 3
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
123456789sssssaaaa Which is the best way to Print Fibonacci Series in Java? Java Basics - Anfänger-Themen 3
J Fibonacci-Reihe Java Basics - Anfänger-Themen 12
G Fibonacci Zahlenreihe Fehler Java Basics - Anfänger-Themen 4
D Fibonacci overflow integer Java Basics - Anfänger-Themen 8
N Dynamisches Programmieren/Fibonacci Java Basics - Anfänger-Themen 1
V Fibonacci Folge Java Basics - Anfänger-Themen 4
M Methoden Fibonacci-Folge Java Basics - Anfänger-Themen 6
J Fibonacci -Folge rekursiv berechnen Java Basics - Anfänger-Themen 18
P Fibonacci -Verallgemeintert Java Basics - Anfänger-Themen 2
K Methoden Fibonacci in Array mit rekursiver Methoden Java Basics - Anfänger-Themen 19
M Fibonacci rekursiv mittels Cache Java Basics - Anfänger-Themen 17
T Stack Overflow - Rekursive Fibonacci Java Basics - Anfänger-Themen 10
M Fibonacci-Folge mit while-Schleife Java Basics - Anfänger-Themen 4
P fibonacci - do while Statement Logik Fehler Java Basics - Anfänger-Themen 5
A Fibonacci-numbers Java Basics - Anfänger-Themen 9
K Rekursion Fibonacci Java Basics - Anfänger-Themen 3
Z Fibonacci rekursiv meine Erklärung stimmt so? Java Basics - Anfänger-Themen 2
Z Fibonacci Array Erklärung Java Basics - Anfänger-Themen 5
A Gerade Terme der Fibonacci-Folge aufsummieren Java Basics - Anfänger-Themen 12
M Fibonacci, Fakultaet, GGT Java Basics - Anfänger-Themen 9
S Fibonacci Folge Java Basics - Anfänger-Themen 34
D Fibonacci Java Basics - Anfänger-Themen 11
M Fibonacci-Linear und Rekursiv Java Basics - Anfänger-Themen 14
W Fibonacci Zahlenberechnung Java Basics - Anfänger-Themen 9
X Fibonacci mit durchschnittlicher Zeit Java Basics - Anfänger-Themen 5
I Fibonacci-Folge , direkter Weg. Java Basics - Anfänger-Themen 5
G Fibonacci Algorithmus Java Basics - Anfänger-Themen 22
S Fibonacci Rückrechnung! Java Basics - Anfänger-Themen 5
G fibonacci was stimmt an meinem code nicht? Java Basics - Anfänger-Themen 2
S Fibonacci Zahlenvergeich Java Basics - Anfänger-Themen 6
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
P Aus Text Datei nur Zahlen übernehmen Java Basics - Anfänger-Themen 13
K Warum werden immer noch doppelte Zahlen ausgegeben ? Java Basics - Anfänger-Themen 13
M negative Zahlen bei Intervallen Java Basics - Anfänger-Themen 10
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
M 3 Zahlen miteinander vergleichen Java Basics - Anfänger-Themen 18
J Taschenrechner mit mehr als 2 Zahlen. Java Basics - Anfänger-Themen 18
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
B Alle Zahlen finden, die 3 bestimmte Ziffern enthalten? Java Basics - Anfänger-Themen 9
K Java gleicher Wert von Zahlen? Java Basics - Anfänger-Themen 5
I aus 2 random zahlen soll nur die ungerade summe der beiden genommen werden. Java Basics - Anfänger-Themen 13
J Operatoren Zahlen addieren Java Basics - Anfänger-Themen 13
B Threads Counter mit ungeraden Zahlen Java Basics - Anfänger-Themen 32
JavaBeginner22 Java 2 Zufalls zahlen generieren. Java Basics - Anfänger-Themen 11
X Wie kann man ein Regex erstellen, die 8-Bit-Binär-Zahlen darstellen. Java Basics - Anfänger-Themen 1
M Stream mit den ersten n natürlichen Zahlen Java Basics - Anfänger-Themen 4
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
sserio Befreundete Zahlen Java Basics - Anfänger-Themen 7
AhmadSlack Verzweigungen zahlen multiplizieren Java Basics - Anfänger-Themen 4
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
U Lotto-Zahlen App Java Basics - Anfänger-Themen 34
berserkerdq2 Wie würde man einen regulären Ausdruck in Java schreiben, der prüft, dass zwei bestimtme Zahlen nicht nebeneinadner sind? Java Basics - Anfänger-Themen 3
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Zahlen bis zu einem bestimmten Grenzwert ausgeben Java Basics - Anfänger-Themen 11
00111010101 Objektorientiertes Programmieren mit Vererbung (Zahlen in Array verschwinden) Java Basics - Anfänger-Themen 3
P Zweidimensionales Array als Tabelle mit befüllten Zahlen Java Basics - Anfänger-Themen 10
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
emx-zee Erste Schritte NullPointerException, Array mit zufälligen Zahlen füllen Java Basics - Anfänger-Themen 2
W Bestimmte Zahlen bei Math.random ausschließen? Java Basics - Anfänger-Themen 31
K Erste Schritte "Taschenrechner" zeigt keine Komma Zahlen an. Java Basics - Anfänger-Themen 8
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
H Häufigkeit von Zahlen ermitteln Java Basics - Anfänger-Themen 23
sashady Zahlen rekursiv zerlegen und Ziffern addieren Java Basics - Anfänger-Themen 38
H Zahlen kürzen Java Basics - Anfänger-Themen 2
ansystin Teilerfremde Zahlen ausgeben + Zahlenausgabe speichern Java Basics - Anfänger-Themen 3
B Häufigkeit einzelner Zahlen in einem Array Java Basics - Anfänger-Themen 6
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
H Eingegebene Zahlen mit Array ausgeben Java Basics - Anfänger-Themen 18
I 12 Spalten von jeweils 30 Zahlen in Konsole ausgeben Java Basics - Anfänger-Themen 6
R Array mit Unter- und Obergrenze ganze Zahlen dazwischen erscheinen nicht Java Basics - Anfänger-Themen 1
OZAN86 For Schleife von 1-50 die Zahlen werden durch ein Komma getrennt Java Basics - Anfänger-Themen 10
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
mhmt_03 dafür sorgen, dass im JTextfield nur zahlen eingebbar sind Java Basics - Anfänger-Themen 9
Ianatrix Zahlen von a bis b berechnen Java Basics - Anfänger-Themen 7
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
P Nutzer entscheiden lassen, wie viele Zahlen dieser in ein Array eingeben möchte. Java Basics - Anfänger-Themen 6
T Bestimmte Zahlen ausgeben mit einer whilfe Schleife Java Basics - Anfänger-Themen 21
H Alle Geraden zahlen bis 10 ausgeben Java Basics - Anfänger-Themen 11
java3690 Liste mit zufälligen zahlen füllen Java Basics - Anfänger-Themen 27
macle Rekursive String Methode, Gerade Zahlen rausfiltern Java Basics - Anfänger-Themen 10
M Regex nur Zahlen und Punkt zulassen, Keine Eingabe(Leeres TextFeld) nicht zulassen Java Basics - Anfänger-Themen 6
L Mit Zahlen im String rechnen Java Basics - Anfänger-Themen 19

Ähnliche Java Themen

Neue Themen


Oben