Schreiben Sie ein Programm in Java, welches zunächst die Anzahl der einzugebenden Werte einliest. Anschließend sollen die Werte(positiveGleitkommazahlen) nacheinander von der Konsole gelesen und in einem array gespeichert werden.
Nachdem das geometrische Mittel dieser Zahlen bestimmt wurde, soll sowohl dieses ,als auch der Inhalt des Arrays in umgekehrter Reihenfolge ausgegeben werden.
Wie mache ich das 1.
Die Anzahl der Werte einliest und dann in einem Array speichert. Das also die Arraylänge von der Eingabe abhängt?
Danke
D.h du liest eine Zahl n ein und mit einer for Schleife legst du dann ein array an an der 0. bis zur 4. Stelle. Warum muss man dann sageb dass die values im Array vom Typ double sein sollen. Das array ist doch als typ doublr erzeugt worden?
Meinst du das values[i] = sc.nextDouble();?
Ich könnte auch versuchen, da einen String reinzupacken (würde aber nicht funktionieren).
Die rechte und linke Seite sind zunächst einmal unabhängig zu betrachten. Dann wird geschaut, ob sie auch den gleichen Typ haben (bzw. ein impliziter Cast erlaubt ist, man kann auch ein int in eine double Variable schreiben).
Original von eulerscheZahl
Meinst du das values[i] = sc.nextDouble();?
Ich könnte auch versuchen, da einen String reinzupacken (würde aber nicht funktionieren).
.
Ja genau. Warum muss das eine Zahl nochmal in jedes Feld eingelesen werden. Es ist doch schon vom Typ double?
Dabei seit: 06.11.2013
Beiträge: 638
Herkunft: Heidelberg
Erstens: es kommt deshalb immer 0 raus, weil Du "speicher" mit einer 0 initialisierst und dann nur andere Zahlen drauf multiplizierst. Aber eine 0 bleibt bei Multiplikation 0, immer...
Zweitens: wenn Du zu einer bestehende Zahl etwas dazu multiplizieren willst, dann schrieb doch besser
code:
1:
speicher *= Werte[i];
Drittens: meines Wissens ist das geometrische Mittel nicht die Quadratwurzel des Produkts sondern die n-te Wurzel der n Faktoren des Produkts. Wenn Du also 4 Zahlen eingelesen hast und diese auch zusammen multiplizierst, dann musst Du am Ende die 4-te Wurzel und nicht einfach die Quadratwurzel ziehen.
Gruß
Marco
PS: warum heißt die Klasse eigentlich "sotierer"? Wenn es um das Sortieren geht, dann fehlt ein r und außerdem hat diese Aufgabe ja nichts mit sortieren zu tun.
13.11.2017 00:41
Informatikanfänger20 unregistriert
Danke für deine Erläuterungen
Ja das stimmt. Es ist die n-te Wurzel. Wie mache ich das?
Speicher darf nicht 0 sein, soll ich es mit 1 initialsieren?
Ich werde die Klasse umbennen. Sotierer war einfach schon gespeichert
Dabei seit: 06.11.2013
Beiträge: 638
Herkunft: Heidelberg
So weit ich weiß geht das nur über die Funktion Math.pow(x, y). Die rechnet x-hoch-y aus. Die n-te Wurzel ist ja einfach x^(1/n). Allerdings hier Vorsicht: wenn Du nur 1/n schreibst und n ein int ist, macht er eine Ganzzahldivision und in diesem Fall würde dann immer 0 raus kommen. Du musst dann also 1.0/n schreiben.
Gruß
Marco
Edit: huch, da habe ich zu lange getippt. Karlito war ganze 10min schneller!
Dabei seit: 06.11.2013
Beiträge: 638
Herkunft: Heidelberg
Ich verstehe den letzten Teil der Aufgabe aber nicht so, dass das Array in sich umgedreht werden soll, sondern nur dass die Ausgabe in umgekehrter Reihenfolge passieren soll. Das könntest Du auch einfach machen, indem Du in der for Schleife von n-1 runter nach 0 zählst und alle Elemente direkt ausgibst.
Ich weiß nicht, was genau Du noch korrigiert hast, aber in der letzten for-Schleife steht die Zahl 4 als Obergrenze. Muss das aber nicht passend zu n sein und nicht immer 4?
Außerdem stimmt das mit dem Reihenfolge umdrehen überhaupt nicht. Das ist ja fast eine Art sortieren oder so...