String aus Zahlen multiplizieren -> unendlich große !

Status
Nicht offen für weitere Antworten.

Gurkus

Mitglied
Hi
wir haben die Aufgabe gestellt bekommen beliebig große Zahlen zu multiplizieren.
Somit ganz einfach die Aufgabenstellung:
Erstellen sie ein Programm welches beliebig große Zahlen miteinander multiplizieren kann.

Somit läuft es schon mal auf Strings hinaus.
Nur ich komme einfach nicht weiter.
Mein Problem liegt darin das ich die Zahlen zwar multiplizieren kann Stelle für Stelle
aber ich kann später das Ergebnis nicht zusammen addieren.
also bei einer Zahl z.B. 999*999 fange ich an mit 9*9=81.
Somit weise ich einem String Buffer den Wert 81 zu.
Aber wenn ich dann 9*90=810 dazu addieren will finde ich keinen gescheiten Algorithmus
um dies zu addieren ...
argh das beispiel ist vielleicht auch schlecht gewählt aber wenn situationen kommen wo ich 19+19 addieren muss
kommen bei mir tausend Probleme auf. Durch diesen "Überlauf".
Ich weiss nicht wie ich es hinbekommen soll ...
Vielleicht hat jemand nen kleinen Tip das wäre super !
Mein Kopf raucht :bahnhof:

bis denne
greetz nils
 

tfa

Top Contributor
Nimm keinen String, sondern ein int-Array, pro Ziffer ein int. Nach den Multiplikationsschritten gehst du das Array von hinten nach vorne durch um den Zehnerübertrag zu berechnen.
@hdi: Ich glaub, eine Lösung mit BigInteger zählt nicht.
 

ARadauer

Top Contributor
es hilft vielleicht, wenn du weißt wie du aus einem String ein int und aus einem int einen String machst...

Code:
		   String zahl = "1234"; 
		   int x = Integer.parseInt(zahl);
		   String xStr = x+"";

wieso multiplizierst du stelle mit stelle?
 

SegFault

Bekanntes Mitglied
Weil dass das Prinzip des schriftlichen Multiplizierens ist. Hatten wir glaube ich in der 4. Klasse??? K.A. ich kanns eigentlich auch kaum noch.

Das Problem was beim umwandeln von Strings in ints auftritt ist ein ggf auftretender überlauf. Die Aufgabe von Gurkus war explizit gestellt "beliebig lange" tfa hat einen guten Ansatz für das Problem gepostet.
 

babuschka

Top Contributor
Prinzipielle Frage:

Der Ansatz von Gurkus ist doch prinzipiell gut, oder? Also sich klarzumachen, wie man das ganze per Hand lösen würde und das dann so umzusetzen.
Wenn ich es richtig verstanden habe, läuft tfas Vorschlag ja auf dasselbe Prinzip hinaus.
 

0x7F800000

Top Contributor
ja, nur bei tfa's vorschlag muss man sich nicht mit irgendwelchen unbrauchbaren zwischenergebnissen in string-form rumschlagen, sondern es auch direkt in einer angebrachten form abspeichern.
 
G

Gast

Gast
hi ihc hab ne frage ist dringend und zwar muss ich ein javaprojekt anlegen
von x zahlen muss das programm die kleinste zahl rausfinden muss auhc mit negativen zahlen gehen o.o?
könnt ihr mir helfen^^? plz
 

ARadauer

Top Contributor
das ist keine frage!
sondern das standard beispiel der ersten vorlesung... wenn du das nicht packst kannst du gleich schon exmatrikulieren ;-)

zeig mal was du bereits hast und wo das problem liegt...
 

Saxony

Top Contributor
Hiho,

das Minimum kann man für beliebig viele Zahlen relativ einfach bestimmen:

Einfach durch ein int Feld laufen und zwei Werte vergleichen ist einer kleiner, so ist dieser dann das aktuelle minimum. Am ende des Durchlaufs hast du den kleinsten Wert gefunden.

bye Saxony
 

Saxony

Top Contributor
Um es mal kurz und schmerzlos zu machen:

Code:
public static void main(String[] args) {
		
	int[] zahlen = {5, 1, 12, -8, 4, -2, 5, 10, -6};

	System.out.println(min(zahlen, 1, zahlen[0]));
}
	
private static int min(int[] f, int pos, int min) {
		
	if (pos < f.length) pos++;
	if (pos == f.length) return min;
		
	return (f[pos] < min)?min(f, pos, f[pos]):min(f, pos, min);
}

bye Saxony
 

Templon

Bekanntes Mitglied
Und hier das ganze noch iterativ =)

Code:
	public static void main(String[] args) {
		double[] input = {1.5,4.2,-32,104,32,-135.25};
		double[] input2 = {};
		System.out.println(min(input));
		System.out.println(min(input2));
		System.out.println(min(null));

	}
	
	/**
	 * Gibt den kleinsten Wert des gegeneben Arrays zurück. Wenn das gegebene Array 
	 * <code>null</code> oder leer ist, gibt diese Methode <code>Double.NaN</code> zurück.
	 */
	public static double min(double [] input) {
		if (input == null || input.length == 0) return Double.NaN;
		
		double  min =  input[0];
		for (int i = 0; i < input.length; ++i) {
			min = Math.min(min, input[i]);
		} 
		return min;
	}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
macle Rekursive String Methode, Gerade Zahlen rausfiltern Java Basics - Anfänger-Themen 10
L Mit Zahlen im String rechnen Java Basics - Anfänger-Themen 19
L Zahlen in String bestimmt schneiden! Java Basics - Anfänger-Themen 10
D Java doppelte Zahlen auch über 10 in einem String entfernen Java Basics - Anfänger-Themen 2
S Zahlen an String anfügen Java Basics - Anfänger-Themen 2
S String ab dem Wechsel Buchstaben zu Zahlen splitten Java Basics - Anfänger-Themen 14
T Array mit String, Zahlen in If Saetze packen Java Basics - Anfänger-Themen 3
G String Elemente auf Zahlen Überprüfen Java Basics - Anfänger-Themen 21
M String nach Zahlen durchsuchen Java Basics - Anfänger-Themen 21
M Anzahl Zahlen in String Java Basics - Anfänger-Themen 21
X String Sonderzeichen/Zahlen erkennen Java Basics - Anfänger-Themen 3
C Problem mit der Extraktion von Zahlen aus einem String Java Basics - Anfänger-Themen 8
M String mit mehreren Zahlen in Integer-Array Java Basics - Anfänger-Themen 2
G Zahlen aus String filtern? Java Basics - Anfänger-Themen 3
S String Vergleich mit Passwort geht nur bei Zahlen ? Java Basics - Anfänger-Themen 7
A Beliebiger String --> Buchstaben und Zahlen Java Basics - Anfänger-Themen 4
P String auf Zahlen beschränken Java Basics - Anfänger-Themen 16
P Zahlen aus String auslesen und dann sortieren. Java Basics - Anfänger-Themen 2
V String überprüfen, nur Punkte und Zahlen erlaubt Java Basics - Anfänger-Themen 7
S String in ACSII Zahlen umwandeln Java Basics - Anfänger-Themen 10
G String buchstaben in Zahlen umwandeln Java Basics - Anfänger-Themen 5
F Zahlen ine-notation aus string Java Basics - Anfänger-Themen 4
A String in Zahlen/Summe umformen Java Basics - Anfänger-Themen 2
D String überprüfen auf Zahlen. Java Basics - Anfänger-Themen 16
O String nur importieren wenn nur zahlen da sind? Java Basics - Anfänger-Themen 7
P Integer aus String erzeugen, der nicht nur Zahlen hat. Java Basics - Anfänger-Themen 2
V Zahlen sortieren und String zuweisen Java Basics - Anfänger-Themen 7
S String --> Zahlen herausschneiden an bestimmten Positione Java Basics - Anfänger-Themen 3
P String aus Zahlen auslesen und in einem Array speichern Java Basics - Anfänger-Themen 3
G zwei Zahlen bei String.valueOf(char c) in JTextField Java Basics - Anfänger-Themen 7
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
E String zerlegen aus args Java Basics - Anfänger-Themen 1
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
I Zerlegen von String Java Basics - Anfänger-Themen 3
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
I String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer) Java Basics - Anfänger-Themen 13
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben