Schleife mit BigInteger

Status
Nicht offen für weitere Antworten.

andreas2505

Bekanntes Mitglied
Hallo,

icst es möglich z.B. eine for-Schleife zu machen in der auch BigInteger als Laufvariable genommen wird.

z.B.:

Java:
public static BigInteger potenz(BigInteger basis, BigInteger exp) {
        BigInteger result = basis;
        for (BigInteger i=1; i<exp; i++) {
            result = result * basis;
        }
        return result;
    }
 

hdi

Top Contributor
Wenn du den Code doch schon geschrieben hast, warum kompilierst du ihn nicht einfach und kuckst nach? Ich weiss es grad selber nicht, denke aber schon. Allerdings weiss ich nicht ob sowas wie "<" auf BigInteger definiert ist, d.h. das musst du dann evtl über passende Methoden lösen, zB: i.lessThan(BigInteger.ONE) oder sowas.
 

Landei

Top Contributor
Tja, deine Syntax ist ja hübsch, aber leider tun sich die Java-Bonzen noch etwas schwär mit Operatorüberladungen...

Java:
public static BigInteger potenz(BigInteger basis, BigInteger exp) {
        BigInteger result = basis;
        for (BigInteger i=BigInteger.ONE; i.compareTo(exp)<0; i = i.add(BigInteger.ONE)) {
            result = result.multiply(basis);
        }
        return result;
    }
Es gibt effizientere Wege zur Berechnung der Potenz. Der Exponent als BigInteger ist auch nicht sinnvoll, denn wenn der größer als ein long (2^64) wird, ist dein Speicher sowieso voll - selbst wenn die Basis nur 2 ist.
 

Landei

Top Contributor
Vielleicht daran, dass 1 ein int und kein BigInteger ist?

Ganz im Ernst, das sind zwei verschiedene Paar Schuhe: int ist ein primitiver Typ, von dem es Listerale gibt (0, 1 , 4711, 0xabcd), und BigInteger ist eine Klasse, die man gebastelt hat, damit Zahlen beliebig groß werden können. Als Klasse stehen BigInteger die "primitiven" Operatoren nicht zur Verfügung, genausowenig, wie +, - usw. bei den anderen Zahlen-Wrapper-Klassen (Integer, Long...) funktionieren.
 
Zuletzt bearbeitet:

andreas2505

Bekanntes Mitglied
hab noch ne frage:

ich habe nun die folgende zeile:

Java:
        BigInteger basis = (BigInteger) (Math.random().multiply((n.subtract(new BigInteger("2")))).add(new BigInteger("2")));

mit dieser will ich basis = Zufallszahl zwischen 2 und n-2 erzeugen

aber da kommt die fehlermeldung :

double cannot be dereferenced.

Was muss ich da ändern?
 
S

SlaterB

Gast
warum so viel auf einmal und dann die Welt nicht mehr verstehen?

double d = Math.random();
d.multiply(..);

??

an einem double kann man keine Methode aufrufen
 
S

SlaterB

Gast
new BigInteger("2")
bekommst du hin,
da ist es nicht zu erraten, wie du wohl aus einem double oder noch anderen Werten ein Objekt machst?
schau dir doch alle Konstruktoren und sonsten Methoden von BigInteger an, besonders die statischen

BigInteger ist allerdings wirklich nur für ganze Zahlen gedacht, während Math.random() einen Wert zwischen 0 und 1 liefert,
dieses Dilemma kann ich auch nicht für dich lösen..
 

0x7F800000

Top Contributor
Irgendwie scheint es dir nicht bewusst zu sein, was ein BigInteger ist.
Ist dir klar, dass mit solchen Zahlen einfach nichts, was exponentiellen Aufwand oder exponentiellen Speicherplatzverbrauch hat, zu deinen Lebzeiten funktionieren kann?
  • Wenn du die minimal sinnvollen Argumente [c]basis=2[/c] [c]exp=2^64[/c] nimmst, dann brauchst du etwa 2097152 Terabyte um das Ergebnis abzuspeichern
  • mal angenommen du könntest pro Sekunde 1 Milliarde BigInt-Multiplikationen durchführen (das ist sicher nicht der Fall), dann brauchst du für den minimalen sinnvollen Exponenten mit deiner Methode etwa 558.5 Jahre für die Berechnung. Siehe Square and Multiply.
  • zufälligen BigInt würfeln zu wollen, und dafür Math.random() zu verwenden ist totaler blödsinn, weil double eben nur die vergleichsweise lächerlichen 2^64 verschiedene Zustände annehmen kann (bzw. hier nicht mal das, wegen des Intervalls). Da müsste man eher ein ganzes byte-Array mit zufälligen Werten füllen, und daraus BigInt erzeugen. Oder einfach in die API schauen und BinInteger(int, Random) nehmen.
 
Zuletzt bearbeitet:
S

SlaterB

Gast
wer sagt denn, dass der Exponent nicht 3 oder 5 ist, sondern 2^64?
dass für kleine Exponenten ein anderer Typ reicht, wurde schon erwähnt, der Rest zu TeraByte + Jahren ist doch sinnlos, besonders ohne Smily
 

andreas2505

Bekanntes Mitglied
also abgesehen davon, dass es vlt. nicht der beste weg ist, habe ich es immer noch nicht rausgefunden wie ich es mache, dass es funktioniert.
Finde nur die Methode valueOf bei BigOInteger, aber damit klappts auch nicht.
Kann mir nicht schnell wer einfach die richtige Variante schreiben?
 
S

SlaterB

Gast
was soll denn genau passieren?
gibt doch mal paar Beispielrechnungen

Math.random() liefert immer eine Zahl zwischen 0 und 1, als BigInteger ist das standardmäßig 0,
brauchst du vielleicht BigDecimal?..
 

andreas2505

Bekanntes Mitglied
also ich will damit eine zufällige zahl zwischen 2 und n-2 erzeugen (eine ganze zahl)
Ich nehme halt BigInteger, weil sie auch sehr groß sein soll/kann.

Ich weiß ja dass Math.random eine Zahl zwischen 0 und 1 erzeugt, aber wenn man sie mit (n-2) multipliziert und +2 macht hat man ja den entsprechenden Bereich.
Und durch das Casten müsste es dann ein BigInteger sein,aber das klappt ja nicht richtig.
 
S

SlaterB

Gast
dann nimm BigDecimal, wandle n und den double-Wert in BigDecimal um, das geht nun wirklich über Konstruktoren/ valueOf usw,
mutipliziere, und am Ende zum BigInteger runden
 

Painii

Bekanntes Mitglied
also ich will damit eine zufällige zahl zwischen 2 und n-2 erzeugen (eine ganze zahl)
Ich nehme halt BigInteger, weil sie auch sehr groß sein soll/kann.

Ich weiß ja dass Math.random eine Zahl zwischen 0 und 1 erzeugt, aber wenn man sie mit (n-2) multipliziert und +2 macht hat man ja den entsprechenden Bereich.

[0...n-2] alles +2 = [2...n]
Du müsstest das ganze mit (n-4) multiplizieren wenn du am ende auf n-2 kommen willst.

Casten ist ne schlechte Idee, BigInteger sind eben keine primitiven int.
 

andreas2505

Bekanntes Mitglied
das passt schon mit den grenzen!

Aber zu dem davor:
Wenn ich das als double nehme und dann in BigDecimal umwandle, dann hab ich ja wieder das Problem dass die größe des doubles begrenzt ist.
oder irre ich mich da?
 
S

SlaterB

Gast
so genau muss es werden?
nun, dann musst du eine riesige Zufallszahl erzeugen, je nachdem wie groß n ist
für n = 43490803480583420840980498 brauchst du ungerechnet sagen wir mal 40 Bits

einfacheres Beispiel:
n = 5, dann 3 Bits
also eine Zufallszahl 0-7

problematisch sind nun die Fälle 6 und 7, die am besten ignorieren,
solange Zufallszahlen wiederholen, bis das Ergebnis zwischen 0 und 5 liegt oder 1 bis 5 oder +2 = 3-7, das ist variabel

-----------

das ganze geht auch anschaulicher im Zehner-System,
wenn n = 43490803480583420840980498 20 Stellen hat,
dann bilde 20 Zufallszahlen 0-9, füge die zusammen (etwa als String) und du hast eine entsprechend große Zufallszahl,
wieder zu große Zahlen ignorieren,
wenn man n entsprechend analyisiert könnte man gleich bei der ersten Ziffer alles > 4 ignorieren
 
Zuletzt bearbeitet von einem Moderator:

0x7F800000

Top Contributor
@SlaterB:
wer sagt denn, dass der Exponent nicht 3 oder 5 ist, sondern 2^64?
Weil es nicht danach aussieht, als wollte der OP irgendein allgemeines Interface implementieren, das BigInteger-wertige Exponenten vorschreibt? In irgendeinem allgemeineren Kontext würde noch sinn machen, isoliert macht's aber keinen Sinn, das sollte das Beispiel veranschaulichen... Smileys hab ich hier auch noch welche vorrätig: ;)

@OP:
Java:
BigInteger n=new BigInteger("123456789987654321");
BigInteger r=new BigInteger(n.bitLength(),new Random())
.mod(n.subtract(new BigInteger("4"))).add(new BigInteger("2"));
sowas ungefähr...? Was bitLength genau liefert weiß ich nicht, paar bits draufaddieren schadet evtl nicht.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Problem mit BigInteger und Schleife Java Basics - Anfänger-Themen 13
R Best Practice Problem mit (einfacher) Doppelt-Schleife Java Basics - Anfänger-Themen 53
C Abbruch einer Schleife mit break, meine Übung funktioniert nicht richtig Java Basics - Anfänger-Themen 4
C Erste Schritte While-Schleife Java Basics - Anfänger-Themen 3
M While-Schleife mit Wartezeit Java Basics - Anfänger-Themen 15
T Ich brauche eine Schleife die eine beliebige Zahl so lange durch 10 teilt bis zur Null Java Basics - Anfänger-Themen 5
DrahtEck Schleife soll wieder da anfangen wo ich es möchte ! Java Basics - Anfänger-Themen 17
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Ranger229 Endless loop in while Schleife Java Basics - Anfänger-Themen 3
MaZ Quadrat Schleife(Pyramide) Java Basics - Anfänger-Themen 9
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
P Wie kann diese Schleife beenden Java Basics - Anfänger-Themen 1
T float soll durch schleife die größte mögliche Zahl herausfinden, Ausgabe ist aber "Infinity" Java Basics - Anfänger-Themen 1
T Variable in Schleife deklarieren, Speicherplatz, Garbage Collector Java Basics - Anfänger-Themen 10
Ostkreuz While Schleife neustarten Java Basics - Anfänger-Themen 20
S Verschachtelte for-Schleife Java Basics - Anfänger-Themen 2
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
laxla123 Verschachtelte If-Else Schleife Java Basics - Anfänger-Themen 21
S Erste Schritte do-while Schleife Münzwurf Java Basics - Anfänger-Themen 1
S while Schleife Taschenrechner Java Basics - Anfänger-Themen 1
P Best Practice While loop schleife Java Basics - Anfänger-Themen 5
ohneInformatik; For Schleife. Was macht dieser Code?? Java Basics - Anfänger-Themen 5
I For Schleife Summe berechnen Java Basics - Anfänger-Themen 13
A Erste Schritte Aufgabe mit while Schleife Java Basics - Anfänger-Themen 11
R do while Schleife Verständnisfrage Java Basics - Anfänger-Themen 2
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
N Warum Springt iterator nur in der Schleife weiter Java Basics - Anfänger-Themen 9
J for Schleife kleinste Zufallszahl finden Java Basics - Anfänger-Themen 25
A Return in While Schleife Java Basics - Anfänger-Themen 6
M Erste Schritte While Schleife / Ausgabe von buchstabe & ASCII Wert Java Basics - Anfänger-Themen 4
J do..while Schleife Java Basics - Anfänger-Themen 14
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
B Automatisierte Ausgabe (Schleife, If-Abfrage?) Java Basics - Anfänger-Themen 24
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
T Mit jedem Wert in der for-Schleife weiter arbeiten Java Basics - Anfänger-Themen 3
berserkerdq2 Warum muss man manchmal in der RUnmethode sleep in eine schleife tun? Java Basics - Anfänger-Themen 9
F for-Schleife halbiert Durchläufe ungewollt Java Basics - Anfänger-Themen 6
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
Bugs Bunny Fehlerhafte Berechnung beim erneuten Durchlaufen der Schleife Java Basics - Anfänger-Themen 5
J Methoden iterator for-schleife (hasNext() ) Java Basics - Anfänger-Themen 7
S Was macht ++ ohne Schleife? Java Basics - Anfänger-Themen 4
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
Neuling47 for schleife Java Basics - Anfänger-Themen 6
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
B Zuweisungen und Methodenaufrufe in Bedingung der while Schleife? Java Basics - Anfänger-Themen 2
JavaBeginner22 Würfeln bis 6 while Schleife Java Basics - Anfänger-Themen 13
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
xanxk Problem For-Schleife mit Charakter Java Basics - Anfänger-Themen 2
W Schleife und einmal variable++ zu viel Java Basics - Anfänger-Themen 20
sgtcoopa Array übergeben Schleife Java Basics - Anfänger-Themen 0
T Mäxchenspiel mit Schleife Java Basics - Anfänger-Themen 3
D try/catch-Block bei for-Schleife Java Basics - Anfänger-Themen 14
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
J Schleife Problem Java Basics - Anfänger-Themen 2
X Hilfe beim Übertragen in eine For-Schleife Java Basics - Anfänger-Themen 1
L while Schleife mit 2 Bedingung endet nicht Java Basics - Anfänger-Themen 3
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
K Schleife berechnet kein Ergebnis (Vererbung) Java Basics - Anfänger-Themen 6
S Sentinel-Schleife Java Basics - Anfänger-Themen 0
D Array mit while-schleife Java Basics - Anfänger-Themen 12
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
P9cman Vokal Zähler mit switch case und for-Schleife Java Basics - Anfänger-Themen 4
B do while Schleife Java Basics - Anfänger-Themen 3
I Fehler bei for-Schleife Java Basics - Anfänger-Themen 6
S Mit for-Schleife ein 2D JLabel-Array mit veränderbaren Icons erstellen Java Basics - Anfänger-Themen 3
D Codeverständis For-Schleife Java Basics - Anfänger-Themen 4
SergioCK Do while Schleife wiederholen Java Basics - Anfänger-Themen 14
M For-Schleife Java Basics - Anfänger-Themen 20
el_pato DialogFenster wird nicht in Schleife geöffnet? Java Basics - Anfänger-Themen 30
J if-Schleife innerhalb einer if-Schleife wird in der Konsole nicht gelesen Java Basics - Anfänger-Themen 4
EinNickname9 Denkfehler bei einfacher Schleife Java Basics - Anfänger-Themen 83
paulen1 Methoden Unerwünschte Ausgabe bei System.out.print in For-Schleife Java Basics - Anfänger-Themen 8
S Array mit for-Schleife besetzen Java Basics - Anfänger-Themen 7
CptK For-Schleife in Thread nach jedem Durchlauf pausieren Java Basics - Anfänger-Themen 35
M for schleife ohne geschweifte Klammer Java Basics - Anfänger-Themen 15
H For-Schleife bis Index von Eingabe laufen lassen Java Basics - Anfänger-Themen 24
Informatikf Methoden While Schleife Java Basics - Anfänger-Themen 3
U geschachtelte if-Schleife Java Basics - Anfänger-Themen 15
M While Schleife? Java Basics - Anfänger-Themen 4
Poppigescorn Quersumme Berechnen mit einer While Schleife Java Basics - Anfänger-Themen 13
I Potenz berechnen mit for-Schleife Java Basics - Anfänger-Themen 3
J Koordinaten per Schleife ausgeben Java Basics - Anfänger-Themen 6
S Schleife funktioniert nicht Java Basics - Anfänger-Themen 2
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
OZAN86 Methoden for schleife Java Basics - Anfänger-Themen 3
G --i versus i++ in for-Schleife Java Basics - Anfänger-Themen 11
OZAN86 For Schleife von 1-50 die Zahlen werden durch ein Komma getrennt Java Basics - Anfänger-Themen 10
M Wie kann ich Werte die in einer While Schleife sind weiter genutzt werden? Java Basics - Anfänger-Themen 7
T for-each-Schleife, verschiedene Datentypen Java Basics - Anfänger-Themen 1
T Methode um Array mit for-each-Schleife auszulesen Java Basics - Anfänger-Themen 7
Jana01 Schleife Java Basics - Anfänger-Themen 12
H Kann eine while-Schleife ein Programm blockieren? Java Basics - Anfänger-Themen 8
D For Schleife Java Basics - Anfänger-Themen 8
D Doppelte For Schleife / Array Java Basics - Anfänger-Themen 3
TimoN11 Array -> Schleife wieder von vorne durchlaufen lassen Java Basics - Anfänger-Themen 1
O Methode in while-Schleife aufrufen geht nur beim ersten Mal Java Basics - Anfänger-Themen 2
T Variable in for Schleife ansprechen ohne Array ? Java Basics - Anfänger-Themen 25
MiMa log4j als separate Dateien in Schleife? Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben