Potenzierung durch einfache Operatoren

NewJava895

Mitglied
Hallo Java Gemeinde,

ich bin neu hier. Ersteinmal wünsch ich allen einen guten Rutsch ins neue Jahr :)

Nun zu meiner Frage. Ich habe ein Programm angefangen, welches mir eine Potenzrechnung durchführen soll. Die einzige Restrektion hierbei ist, ich darf nur einfache Operatoren verwenden, also Addition und Subtraktion. Ich habe mir bisher umfassend Gedanken gemacht und komme einfach nicht weiter. Ich habe versucht, ersteinmal das einfache Produkt zu berechnen:

Java:
 int result = 0;
       	    for (int i = 1; i <= a; i++) {
       	    	    result += a;
       	    	     }

und anschließend hiermit weiterzurechnen. Leider komme ich an einem Punkt, bei dem mir entweder die Grundkentnisse fehlen oder ich einfach zu kompliziert denke oder einfach dumm bin :)

Ich habe also so versucht :

Java:
for (int i = 1; i <= b; i++) {
       	    	    result += c;
       	    	    }

dann so
Java:
for (int k = 1; k <= b; k++) {
for (int i = 1; i <= a; i++) {
       	    	    c += c;
       	    	    }

...

Also habe ich überlegt wie ich es anstellen kann:

5^5 = 3125 -->
5+5+5+5+5 =25 5^2
25+25+25+25+25=125 5^3
125+125+125+125+125=625 5^4
625+625+625+625+625=3125 5^5

Aber mir fehlt einfach noch ein Stück, wie ich weiter mache. Ich habe auch versucht im Methodenkopf eine Schleife zu platzieren (einfach zum probieren) hat aber auch nicht geklappt, könnt ihr mir einen kleinen Denkanstoß geben?
 
H

hüteüberhüte

Gast
Versuche so:
Java:
int/long potenz = 1;
for (int i = 0; i < exponent; i++) {
  potenz *= basis;
}
 
H

hüteüberhüte

Gast
Ach so! Dann versuche so:
Java:
    public static long pow(int basis, int exponent) {
        long potenz = 1;
        for (int i = 0; i < exponent; i++) {
            long produkt = potenz;
            for (int j = 1; j < basis; j++) {
                potenz += produkt;
            }
        }
        return potenz;
    }

    public static void main(String[] args) {
        System.out.println(pow(5, 3));
        System.out.println(Math.pow(5, 3));
        System.out.println(pow(5, 4));
        System.out.println(Math.pow(5, 4));
        System.out.println(pow(5, 5));
        System.out.println(Math.pow(5, 5));
    }

Guten Rutsch Dir Auch!
 

utnovetur

Mitglied
Um es klarer zu machen, würde ich das mutliplizieren und das potenzieren trennen:

Java:
public class Potenz {
	public static void main(String[] args) {
		int basis = 5;
		int exponent = 4;
		int ergebnis = potenziere(basis, exponent);
		System.out.println(ergebnis);
	}

	private static int multipliziere(int faktor1, int faktor2) {
		int produkt = 0;
		// in einer for-Schleife "+" (von Java) benutzen
		return produkt;
	}

	private static int potenziere(int basis, int exponent) {
		int potenz = 1;
		// in einer for-Schleife die eigene Funktion multipliziere(int faktor1, int faktor2) benutzen
		return potenz;
	}
}

Du hast dann auch die Möglichkeit, erst einmal zu testen, ob das multiplizieren richtig funktioniert, z.B. durch:

Java:
	public static void main(String[] args) {
		int faktor1 = 5;
		int faktor2 = 4;
		int ergebnis = multipliziere(faktor1 , faktor2);
		System.out.println(ergebnis);
	}
(Das Ergebnis sollte in der Größenordnung von 20 liegen)

Ein gute neues Jahr
utnovetur
 
Zuletzt bearbeitet:

Landei

Top Contributor
Zum Jahresabschluss eine herrliche Rube-Goldberg-Maschine:

Java:
import java.util.Iterator;

public class Moessner implements Iterable<Integer> {

    private final int k;
    private final int d;

    private Moessner(int k, int d) {
        this.k = k;
        this.d = d;
    }

    public Iterator<Integer> iterator() {
       return new Iterator<Integer>() {

           private int f = 1;
           private int s = 0;
           private Iterator<Integer> it = k == 1 ? null : new Moessner(k-1,d+1).iterator();

           @Override
           public boolean hasNext() {
               return true;
           }

           @Override
           public Integer next() {
               if (k == 1) {
                   return ++s;
               }
               if (f == d) {
                   f = 1;
                   it.next();
               }
               f++;
               s += it.next();
               return s;
           }

           @Override
           public void remove() {
               throw new UnsupportedOperationException();
           }
       };
    }

    public static int pow(int a, int b) {
        if (a < 0 || b < 0) throw new IllegalArgumentException();
        if (b == 0) return 1;
        if (a == 0 || a == 1) return a;
        for(int x : new Moessner(b,2)) {
            if (--a == 0) return x;
        }
        return 666;
    }

}

Wer (ohne nach "Moessner" zu googlen) sagen kann, wie das funktioniert, hat meine Hochachtung...
 
Zuletzt bearbeitet:

Marco13

Top Contributor
Java:
public class A
{
    static long _(long i, long í, long ì)
    {
        return i==0?ì+1:ì==0?i==1?í:i==2?0:1:_(i-1,í,_(i,í,ì-1));
    }

    public static void main(String args[])
    {
        System.out.println("Increasing second arg by one");
        System.out.println("0 0 = " + _(0, 0, 0));
        System.out.println("4 1 = " + _(0, 4, 1));
        System.out.println("2 8 = " + _(0, 2, 8));
        System.out.println("\n");

        System.out.println("Adding the args");
        System.out.println("0 0 = " + _(1, 0, 0));
        System.out.println("2 1 = " + _(1, 2, 1));
        System.out.println("5 4 = " + _(1, 5, 4));
        System.out.println("\n");

        System.out.println("Multiplying the args");
        System.out.println("0 0 = " + _(2, 0, 0));
        System.out.println("2 3 = " + _(2, 2, 3));
        System.out.println("5 4 = " + _(2, 5, 4));
        System.out.println("\n");

        System.out.println("First to the power of second");
        System.out.println("0 0 = " + _(3, 0, 0));
        System.out.println("0 2 = " + _(3, 0, 1));
        System.out.println("2 3 = " + _(3, 2, 3));
        System.out.println("3 4 = " + _(3, 3, 4));
        System.out.println("\n");

        System.out.println(" x^x^x...^x  (y times)");
        System.out.println("0 0 = " + _(4, 0, 0));
        System.out.println("0 2 = " + _(4, 0, 1));
        System.out.println("2 3 = " + _(4, 2, 3));
        System.out.println("\n");
    }
}
:smoke:
 

NewJava895

Mitglied
Danke euch allen für die Hilfe. Ich habe den oben gen. Code noch etwas verbessert insgesamt sieht es jetzt so aus:

Java:
import java.io.*;
 
class potenz {
    public static void main(String[] args) throws IOException {
 
        int a = leseA();//Basis
        int b = leseB();//Exponent
        int c = rechnePotenz(a,b);
        ausgabePotenz(c,b,a);
    }
 
    public static int leseA() throws IOException {
        BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in));
 
        System.out.println("Geben Sie die Basis ein.");
        String input = stdin.readLine();
        return Integer.parseInt(input);
    }
    
     public static int leseB() throws IOException {
        BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in));
 
        System.out.println("Geben Sie den Exponenten ein.");
        String input = stdin.readLine();
        return Integer.parseInt(input);
    }
    
    public static int rechnePotenz(int a, int b) {
       	   
   {
	
  if (b == 0)
    return 1;
  int answer = a;
  int increment = a;
  if (b < 0)
  	  b = -b;
  if (a < 0)
  	  a = -a;
  for(int i = 1; i < b; i++)
  {
     for(int j = 1; j < a; j++)
     {
        answer += increment;
     }
     increment = answer;
  }
  return answer;
  }
    }
    
    public static void ausgabePotenz(int c, int b, int a) {
        if (a < 0 && (b % 2==0))
    	    System.out.println("Potenz: " + ( - c));
    else
    	System.out.println("Potenz: " + c);    
    }
}

Mit der Rechnung erkennt er auch bei einer negativen Basis, dass bei ungeraden Exponenten das Ergebnis negativ wird! Dies habe ich durch

Java:
if (b < 0)
  	  b = -b;
  if (a < 0)
  	  a = -a;
Damit er einfach mit den Zahlen weiterrechnet und

Java:
public static void ausgabePotenz(int d, int b, int a) {
        if (a < 0 && (b % 2==0))
    	    System.out.println("Potenz: " + ( - d));
    else
    	System.out.println("Potenz: " + d);

Damit er die Ausgabe korrekt gestaltet. Soweit so gut. Aber jetzt habe ich weiter überlegt, was ist mit negativen Exponenten ?! Das hieße ja a^-b = 1/a^b. Ich glaube hier endet die Möglichkeit mit Addition und Subtraktion auf das Ergebnis zu kommen oder? Was haltet ihr von meinem gesamten Programmcode? Gibt es Dinge zu verbessern?

Ich danke euch allen vielmals und wünsch ein Frohes neues Jahr!
 
Zuletzt bearbeitet:
H

hüteüberhüte

Gast
Vieles ist mit Addition (und Subtraktion) möglich. ;)

Um Schnelligkeit geht es hier wohl nicht, sonst schieden die rekursiven Verfahren aus.

@Landei: Ohne zu googlen, dauert es wohl etwas länger, den Code zu verstehen, aber zumindest der Ansatz lässt sich erkennen.

@utnovetur: Warum sollte ich eine so einfach verschachtelte Schleife zusätzlich noch auslagern? Blödsinn, wer das nicht erkennt, ist kein guter Programmierer.
 

Landei

Top Contributor
@Landei: Ohne zu googlen, dauert es wohl etwas länger, den Code zu verstehen, aber zumindest der Ansatz lässt sich erkennen.

Glaube ich nicht, denn das Verfahren ist alles andere als einsichtig. Nehmen wir mal das Vorgehen für die 4. Potenz.

Wir beginnen mit der Folge der natürlichen Zahlen:

1,2,3,4,5,6,7,8,9,10,11,12,13,14,15...

Davon wird jede 4. Zahl gestrichen:

1,2,3,5,6,7,9,10,11,13,14,15...

Die kumulierte Zahlenfolge:

1,3,6,11,17,24,33,43,54,67,81,95...

Davon jede 3. Zahl gestrichen:

1,3,11,17,33,43,67,81...

Die kumulierte Zahlenfolge:

1,4,15,32,65,108,175,256...

Davon jede 2. Zahl gestrichen:

1,15,65,175...

Die kumulierte Zahlenfolge:

1,16,81,256...

Und das ist überraschenderweise die Reihe der 4. Potenzen.

Ich mache das mit meinen Iteratoren "rückwärts", lasse mir also die Werte der jeweils vorigen Reihe "just in time" liefern (sonst wäre es schwer auszurechnen, mit wieviel Werte man eigentlich starten muss für eine gegebene Basis).

Mit leicht abgewandelter Bildungsregel lassen sich übrigens auch Fakultäten berechnen.
 

NewJava895

Mitglied
@ Landei

Das is krass ... Wie kommt man bitte auf sowas? Macht aber Sinn. Nur gehen hier (wenn ich es richtig sehe) auch nur ganzzahlige Potenzen und Potenzen bei denen Basis und Exponent nur positiv sein können. Wobei die Ausgabe bei negativer Basis nicht schwer ist nur bei negativen Exponenten habe ich so meine Probleme. Beim googeln habe ich eine Reihe gefunden, die immer wieder das Komma verschiebt und den Rest ausgibt, also wie beim schriftlich rechnen. Aber fand ich sehr kompliziert.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Rekursive Bruch potenzierung Java Basics - Anfänger-Themen 2
T Ich brauche eine Schleife die eine beliebige Zahl so lange durch 10 teilt bis zur Null Java Basics - Anfänger-Themen 5
X wie bekomme ich durch Eingabeaufforderung definierte double in einen Befehl, welcher 3 erwartete double braucht? Java Basics - Anfänger-Themen 3
T float soll durch schleife die größte mögliche Zahl herausfinden, Ausgabe ist aber "Infinity" Java Basics - Anfänger-Themen 1
H Counter durch gepresste Taste nur auf 1 erhöhen und nicht durchzählen lassen Java Basics - Anfänger-Themen 7
T Eingabe durch eine Zahl dividieren nachgucken? Java Basics - Anfänger-Themen 4
G Programm läuft durch, ohne Eingabe aus dem Chat abzuwarten Java Basics - Anfänger-Themen 4
S IntelliJ geht alle Klassen durch Java Basics - Anfänger-Themen 9
A 1 Leerzeichen durch zwei Leerzeichen ersetzen Java Basics - Anfänger-Themen 4
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
Thomas06 Wie kann man mithilfe von boolean herausfinden ob eine zahl durch 5 und 7 teilbart ist ? Java Basics - Anfänger-Themen 7
A JTextArea entfernen und durch neuen Text ersetzen Java Basics - Anfänger-Themen 8
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
T Variable durch Action Listener ändern Java Basics - Anfänger-Themen 2
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
Agent4nobody Programmstart durch aufruf des interpreters funktioniert nicht Java Basics - Anfänger-Themen 14
obiwanke Ziffern durch ASCII Character ersetzen Java Basics - Anfänger-Themen 8
J Speichern von zwei Variablen durch Auslesen aus einem Numberfield Java Basics - Anfänger-Themen 2
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
S Durch HashMap iterieren Java Basics - Anfänger-Themen 8
A Wenn eine Zahl durch 7 teilbar ist, soll statt der Zahl ein ‘*‘ angezeigt werden. java? Java Basics - Anfänger-Themen 47
K mit <<1 kann man mal 2 machen, mit >>2 geteilt durch zwei und was bewirkt <<<1 und >>>1? Java Basics - Anfänger-Themen 5
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26
F Initialisieren eines Web-Mp3 Players in Tabs durch "booleans" erst wenn Tab geöffnet wird ...? Java Basics - Anfänger-Themen 1
W Werte durch Konsole einlesen Java Basics - Anfänger-Themen 10
C if-Konstrukt durch switch-Konstrukt ersetzen Java Basics - Anfänger-Themen 14
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
Y Wie kann ich Konsoleneingaben durch den Scanner mit JUnit 4 testen? Java Basics - Anfänger-Themen 1
yoskaem Text Color durch Klicken eines Buttons in anderer Activity ändern Java Basics - Anfänger-Themen 2
N for Schleife durch Rekursion ersetzen Java Basics - Anfänger-Themen 6
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
J Eine Position im String durch einen Integer - Wert teilen Java Basics - Anfänger-Themen 5
F Methoden Bitte Helft mir meinen Fehler zu finden. Möchte in diesem Bankenprogramm durch die Konsoleneingabe auswählen welches Konto reduziert und welches erhö Java Basics - Anfänger-Themen 17
E 2D Array - char durch die Matrix "wandern" lassen Java Basics - Anfänger-Themen 7
E Objekt durch Benutzer über Konsole erzeugen - Java Java Basics - Anfänger-Themen 3
F Methode für Teilbarkeit durch 5 tut was anderes.... Java Basics - Anfänger-Themen 3
H Aufruf von Methoden durch Methoden Java Basics - Anfänger-Themen 3
H Wie kann ich durch Methoden definiren? Java Basics - Anfänger-Themen 8
O Mehrfache Scanner-Eingabe durch Komma getrennt Java Basics - Anfänger-Themen 6
M String array durch Eingabe begrenzen Java Basics - Anfänger-Themen 7
J Dynamisches Array durch split()-Funktion? Java Basics - Anfänger-Themen 3
O Typparameter durch Wildcards verallgemeinern Java Basics - Anfänger-Themen 3
G Benutzereingaben durch Zeilenumbruch trennen und in Array individueller Größe speichern Java Basics - Anfänger-Themen 20
B Import Tabelle - Struktur durch User einstellbar Java Basics - Anfänger-Themen 4
K Durch eine Text eingabe etwas Ausführen Java Basics - Anfänger-Themen 5
T Konsolenscanner startet nicht durch Aufruf von Actionlistener Java Basics - Anfänger-Themen 4
A OOP Variable in anderer Klasse durch Methode aufrufen und einer anderen Variable gleichsetzen Java Basics - Anfänger-Themen 2
F Ein Datum (int) durch Methode als String formatieren Java Basics - Anfänger-Themen 2
B OOP While Schleife läuft Endlos durch externen aufruf Java Basics - Anfänger-Themen 2
D While Schleife bei Bedarf durch Eingabe stoppen Java Basics - Anfänger-Themen 15
CptK Interface Curser durch Bild ersetzen & MouseListner Java Basics - Anfänger-Themen 2
H OOP eine Zahl immer weiter durch 2 teilen Java Basics - Anfänger-Themen 15
I Null-Überprüfung durch Lambda-Expressions abkürzen Java Basics - Anfänger-Themen 8
W Teilstring durch Teilstring mittels StringBuilder ersetzen Java Basics - Anfänger-Themen 7
N Denksportaufgabe durch Algorithmus lösen Java Basics - Anfänger-Themen 2
H Array mit Zahlen die durch 3 und 5 teilbar sind erstellen Java Basics - Anfänger-Themen 13
D Interface Frame doppelt durch Aufruf der GUI Klasse Java Basics - Anfänger-Themen 1
J Die Zahl herausfinden die durch 2 - 30 Teilbar ist... Java Basics - Anfänger-Themen 17
M For-Schleife durch zwei versch. Variablen begrenzen Java Basics - Anfänger-Themen 27
W JLabel, Farbe durch Listener ändern Java Basics - Anfänger-Themen 6
T Extrahiertes Objekt durch Getter bekommen Java Basics - Anfänger-Themen 2
R Eine Schleife durch eine Methode schließen? Java Basics - Anfänger-Themen 4
N Operatoren Suchen nach einer bestimmten Eingabe (durch Scanner) Java Basics - Anfänger-Themen 7
S For-Schleife durch "ESC" verlassen? Java Basics - Anfänger-Themen 2
C char in String suchen und durch anderen String ersetzen Java Basics - Anfänger-Themen 2
T static String Variable wird nur beim ersten aufruf durch eine Funktion geändert. Java Basics - Anfänger-Themen 16
V Durch 0 teilen Java Basics - Anfänger-Themen 2
V Durch Methode Objekt löschen Java Basics - Anfänger-Themen 2
D Klasse durch eine Schleife wiederholen Java Basics - Anfänger-Themen 1
J Wie lege ich eine durch Random ausgesuchte Zahl in ein Array? Java Basics - Anfänger-Themen 3
S button kommt durch bild Java Basics - Anfänger-Themen 13
M Ein Bild durch Objekterzeugung zeichnen Java Basics - Anfänger-Themen 5
W Objektname durch Tastaturbefehl eingeben Java Basics - Anfänger-Themen 7
K ArrayList durch ArrayList ersetzen Java Basics - Anfänger-Themen 5
G Objektübergabe durch Parameter Java Basics - Anfänger-Themen 3
P Erste Schritte durch MenuBar verschiedene Fenster öffnen Java Basics - Anfänger-Themen 2
T Jlabel durch Text in 2 anderen Jlabels sichtbar machen Java Basics - Anfänger-Themen 4
T Threads Durch threads gestartete Prozesse killen Java Basics - Anfänger-Themen 2
M ArrayList durch OutputStream in Datei Java Basics - Anfänger-Themen 9
K arraygröße durch variablen Konstruktor? Java Basics - Anfänger-Themen 7
F Erste Schritte Hausaufgaben-Prob. - Iterative Prog. Zahlen aufsummieren, wenn durch k>0 teilbar. Java Basics - Anfänger-Themen 5
T Input/Output Programm beenden durch Eingabe Java Basics - Anfänger-Themen 1
K Tiefen- und Breitensuche beim Baum durch Stack und Warteschlange Java Basics - Anfänger-Themen 1
Ponychan95 Erste Schritte Switch fällt immer bis zum default durch Java Basics - Anfänger-Themen 4
J Warum wird Array durch Methode ohne Rückgabewert verändert? Java Basics - Anfänger-Themen 5
N Durch Objekte iterieren? Java Basics - Anfänger-Themen 3
J Durch 2-Dimensionales Array "bewegen" will nicht so recht hinhauen Java Basics - Anfänger-Themen 2
B Durch eine Liste von Strings laufen Java Basics - Anfänger-Themen 6
D javacode durch Html ausfuehren Java Basics - Anfänger-Themen 13
K Durch ArrayList laufen Java Basics - Anfänger-Themen 8
X Erste Schritte Lernen durch Videoreihe Java Basics - Anfänger-Themen 35
M Möglich? Methode aufrufen deren Bezeichner zur Laufzeit durch einen überg. String festgelegt wird Java Basics - Anfänger-Themen 3
T Best Practice JUnit: Wie Klassen durch Stubs/Mockups ersetzen Java Basics - Anfänger-Themen 7
H Text durch Checkbox erscheinen lassen Java Basics - Anfänger-Themen 2
J Datensätze aus Txt Datei auslesen - Datensätze durch stöbern Java Basics - Anfänger-Themen 5
Ananaskirsche Input/Output Platzhalter durch String in yml-Datein ersetzen Java Basics - Anfänger-Themen 5
F Speicherlast mehrere GB durch kleine png files? Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben