Frage zu negativen und positiven Exponenten in rekursiver Methode

Status
Nicht offen für weitere Antworten.

chillipalmer

Mitglied
Nabend!

Hab hier ne Aufgabe, bei der negative und positive Exponenten aus ganzen Zahlen mit einer Basis aus reellen Zahlen berechnet werden sollen. Hab soweit alles hinbekommen, wollte aber mal wissen, ob es da ne bessere Lösung gibt, außer irgendwelche vordefinierten Methoden aus der Math Class zu benutzen? Muss aber rekursiv sein.

[HIGHLIGHT="Java"]
class Aufgabe_6_7_NegativeExponenten {
public static void main(String[] args) {

double b = 2.0;
int e = -3;
System.out.println(b + " hoch " + e + " ist: " + hoch(b,e));

}

static double hoch( double b , int e )
{
if( e == 0 ) return 1.0;
if( e == 1 ) return b;
if(e == -1) return 1 / b;
if(e < -1) return (1 / (hoch(b, (e * -1)) ));
return( b * hoch( b , e-1 ) );
}
}[/HIGHLIGHT]
 

0x7F800000

Top Contributor
Teil1: (versehentlich wegeditiert)
Nunja, das ist jetzt so eine "theoretisch hübsche" Lösung um rekursion zu demonstrieren, hoffe ich doch?

Normalerweise geht das wesentlich schneller.
Idee:
zB. bei 7^21 rechnet man
7^21=(7^16)*(7^4)*7
Das sind dann insgesammt 5 multiplikationen, statt wie bei deiner methode
7^21=7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7*7
(20 Multiplikationen)
Das ist bereits bei solch mikrigen Exponenten erheblich, wenn die Exponenten ein paar Hundert stellen haben, ist das mit deiner O(exponent) methode nicht in vertretbarer Zeit auszuwerten, in O(log(exponent)) geht das dagegen locker.

=> Da deine Lösung also lediglich schön sein soll, statt zu funktionieren, würde ich die zeilen 13 und 14 einfach rauslöschen, weil sie unnötig sind.
________________________________________________
Teil 2:

Ooooh, manoman, deine Lösung ist unter Java echt nur rein theoretisch funktionsfähig:
mein Java compiler (der standart java-compiler) optimiert die Endrekursion gar nicht weg, deine Methode müllt deshalb den speicher voll und schmeißt exceptions, selbst bei gaaanz mikrigen exponenten, hier ein beispiel:
[HIGHLIGHT="Java"]
public class _ {

public static double powPositive(double b, int e){
if(e==0) return 1;
double temp=powPositive(b,e/2);
temp*=temp;
if((e&1)==1)temp*=b;
return temp;
}

public static double pow(double d, int e){
if(e<0){
return 1/powPositive(d,-e);
}else{
return powPositive(d,e);
}
}


static double hoch( double b , int e ){
if( e == 0 ) return 1.0;
if( e == 1 ) return b;
if(e == -1) return 1 / b;
if(e < -1) return (1 / (hoch(b, (e * -1)) ));
return( b * hoch( b , e-1 ) );
}

public static void main(String[] args) {
double b=1.0000001;
int e=10000000;
System.out.println(
pow(b,e)+"\n"
+Math.pow(b,e)+"\n"
//+hoch(b,e) //<---- geht gar nicht, stackOverflow...
);
}
}
[/HIGHLIGHT]
hab da vorne alles mit meiner (merkwürdig implementierten ebenfalls rekursiven) variante verglichen. Stimmt auf paar nachkommastellen mit "referenzwert" übererein, und verreckt wenigstens nicht bei 5-stelligen Exponenten ;)
 
Zuletzt bearbeitet von einem Moderator:

Der Müde Joe

Top Contributor
so auf die schnelle:
Code:
     public static double pow(double d , int exp) {
    	 return (exp > 0) ? pow1(d, exp) : 1 / pow1(d, -exp); 
     }
     
     private static double pow1(double d, int exp) {
    	 if (exp == 0) {
    		 return 1;
    	 }
    	 if(exp == 1) {
    		 return d;
    	 }
    	 if(exp%2 == 0) {
    		 return pow1(d, exp/2) * pow1(d, exp/2);
    	 } else {
    		 return d * pow1(d, exp-1);
    	 }
     }
 
Zuletzt bearbeitet:
S

SlaterB

Gast
> 7^21=(7^16)*(7^4)*7
> Das sind dann insgesammt 5 multiplikationen

kannst du das näher erläutern? ich komme auf 6 ;)
 

Marco13

Top Contributor
EDIT: Mich hat's da jetzt auch erst rausgehauen... 7^4 * 7^4 ist NICHT 7^16 ;)
a = 7*7 => 1 mul
b = 7^4 = a*a => 1 mul
c = 7^8 = b*b => 1 mul
d = 7^16 = c*c => 1 mul
d*b*7 => 2 mul
 
Zuletzt bearbeitet:

0x7F800000

Top Contributor
> 7^21=(7^16)*(7^4)*7
> Das sind dann insgesammt 5 multiplikationen

kannst du das näher erläutern? ich komme auf 6 ;)
Omfg, jetzt habe ich mich um +-1 verzählt, zerfetzt mich doch in kleine Stücke^^ :autsch:

edit: ne, zerfetzt lieber Den Müden Joe^^, schaut mal was er hier macht statt zu quadrieren:
Code:
return pow1(d, exp/2) * pow1(d, exp/2);
:D
 
S

SlaterB

Gast
abgesehen von dem nicht wiederverwendeten Zwischenwert scheint es aber zumindest in diesem Beispiel auch auf 6 Mulitplikationen hinauszulaufen:
1. 7^2
2. 7^4
3. 7^5
4. 7^10
5. 7^20
6. 7^21
 

0x7F800000

Top Contributor
Naja, die rekursive variante die ich angeschrieben hab benimmt sich zwar ein wenig anders, aber es läuft doch auch in O(lg(e))...
 
S

SlaterB

Gast
will doch niemand schlecht machen,
und wie ich gerade sehe macht sie doch genau das gleiche bis auf den Cache des Zwischenwerts (und Tricksereien wie das eingesparte %2)?

> double temp=powPositive(b,e/2);
hier wird bei e=21 auch b^10 gerechnet, gar nicht b^16

(und das soll wieder kein Vorwurf sein ;) )
 

0x7F800000

Top Contributor
hier wird bei e=21 auch b^10 gerechnet, gar nicht b^16
soll es ja auch nicht.
Die erste methode die ich skizziert habe, läuft in O(lg(e)) ist aber nicht rekursiv. Würde etwa so aussehen:
[HIGHLIGHT="Java"]
public static long pow(long base, long exponent){
long result=1;
for(long x=base; exponent>0;x*=x,exponent>>=1){
if((exponent&1)==1) result*=x;
}
return result;
}
[/HIGHLIGHT]
Das rechnet so wie in meinem ersten Beispiel.

Die rekursive variante läuft auch in O(lg(n)) aber multipliziert die Sachen in einer etwas anderen reihenfolge aus.

und wie ich gerade sehe macht sie doch genau das gleiche bis auf den Cache des Zwischenwerts (und Tricksereien wie das eingesparte %2)?
Tricksereien wie %2 sind wohl echt total egal.
Aber dass der Wert nicht gecachet wird macht doch grade den Unterschied zwischen O(n) und O(lg(n)) aus, also zwischen 1024 und 10, 1048576 und 20, einer million milliarden und 50 usw... Das tut schon weh.
 
S

SlaterB

Gast
> Aber dass der Wert nicht gecachet wird macht doch grade den Unterschied

klar, ich meinte, das ist kein interessanter Bestandteil des Algorithmus sondern ein allgemeines Prinzip,
das zu vergessen ist ein Flüchtigkeitsfehler, keine Strategieentscheidung oder so
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Simple Frage: Positive Zahlen zu Negativen machen. Java Basics - Anfänger-Themen 11
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben