Array rekursiv teilen und aufsummieren

Status
Nicht offen für weitere Antworten.
G

Guest

Gast
folegende aufgabe soll ich lösen:

Schreiben Sie eine weitere Methode, die das Array im Attribut aufsummiert, allerdings
auf rekursive Art. Verwenden Sie dazu eine weitere Hilfsmethode
mit zwei Parametern, die den linken und rechten Index des aufzusummierenden Bereichs
angibt. Diese Methode soll, sofern der spezifizierte Bereich aus mehr als einer
Zahl besteht, den Bereich halbieren und rekursiv jeweils die Summe der beiden Hälften
berechnen, diese zusammenzahlen und die Summe zurückgeben!

das heißt quasi
Code:
public static float sum2 ( float[] array ) {
		
		if (array.length == 1 ) {
			return array[0];
			}
			else {
jetzt muss ich hier die methode sum2 wieder aufrufen, und die soll das array teilen und die beiden arrays aufsummieren oder?
wie kann ich ein array ohne system.arraycopy teilen?
 
S

SlaterB

Gast
> Verwenden Sie dazu eine weitere Hilfsmethode mit zwei Parametern, die den linken und rechten Index des aufzusummierenden Bereichs angibt.

du sollst das Array nicht kopieren, sondern so wie es ist überall durchreichen,
mit den Indexen gibts du an, welcher Teil des Arrays gerade betrachtet wird
 

Leroy42

Top Contributor
... und zwar so:
Code:
public static float sum2 ( float[] array ) { 
       
      if (array.length == 1 ) { 
         return array[0]; 
         } 
         else {
            return sum2(array, 0, array.length()-1);
        }
}
 
G

Guest

Gast
sorry mein fehler.... gehört noch zur aufgabe! das is die rekursive art nach der ich das machen soll!

....das array in 2 hälften aufzuteilen diese einzeln zu summieren und die beiden Ergebnisse aufzuaddieren. Das Aufsummieren der beiden Halften
kann dann wieder rekursiv durch weiteres Aufteilen und Zusammenzahlen geschehen.

das gehört noch dazu...
ich soll das array wenn es nicht der länge 1 entspricht immer in 2 teile teilen, die aufsummieren und den linken und den rechten bereich angeben.... also das array so lange teilen bis es nur noch teile der länge 1 hat.... so hab ich das verstanden!!
oder versteh ich das falsch....
 
S

SlaterB

Gast
wenn du das Array teilen würdest, wozu dann "linken und rechten Index als Parameter übergeben"?
die wären dann ja bestensfalls immer 0 und array-length()-1,
schlimmstenfalls Indexe aus dem Originalarray und noch weniger zu gebrauchen,

und außerdem wäre der Aufwand gigantisch hoch, zig bis tausende Arrays zu erzeugen, je nach Größe des Ursprungsarrays,
macht keinen Sinn

auf logischer Ebene stimmt die Aussage natürlich,
jeder Operationsaufruf summiert nur einen Teil des Arrays
 
G

Guest

Gast
leider muss ich das aber so machen.... hab nachgefragt.... muss das array immer teilen so wie es hier steht!!!
aber leider bekomm ich die rekursion nicht hin!!!
 

Leroy42

Top Contributor
Manno, das "Teilen" ist metaphorisch zu verstehen.

Durch Übergabe von je zwei Indizes (Anfang und Ende des Arrays)
teilst du schon gewissermaßen das Array.

Nimm einfach meine Methodensignatur und versuche daraus
was zu basteln.
 
G

Guest

Gast
Schreiben Sie eine weitere Methode, die das Array im Attribut aufsummiert, allerdings
auf die oben beschriebene rekursive Art. Verwenden Sie dazu eine weitere Hilfsmethode
mit zwei Parametern, die den linken und rechten Index des aufzusummierenden Bereichs
angibt. Diese Methode soll, sofern der spezifizierte Bereich aus mehr als einer
Zahl besteht, den Bereich halbieren und rekursiv jeweils die Summe der beiden Hälften
berechnen, diese zusammenzahlen und die Summe zurückgeben!


oben beschriebene rek.art:

Unter der Annahme, dass große und kleine Zahlen in einem Array ungefahr uberall gleich
häufig vorkommen, ist es daher sinnvoll, das Array in zwei Halften aufzuteilen, diese einzeln
zu summieren und die beiden Ergebnisse aufzuaddieren. Das Aufsummieren der beiden Hälften kann dann wieder rekursiv durch weiteres Aufteilen und Zusammenzählen geschehen.


heißt doch:

methode1. array in 2 teile teilen, und diese dann aufsummieren!
und zwar durch so langes teilen des arrays bis die teilarrays 1 lang sind und diese dann aufsummieren...
das ganze dann mit der hilfsmethode

hilfsmethode:

soll jeweils den startwert der beiden teilarray wiedergeben! - falls das teilarray länger als 1 ist soll dieser wieder geteilt und rekursiv aufsummiert werden!


quasi einmal rekursiv teilen und in der hilfsmethode rekusiv ausummieren...

da ist doch das teilen nicht metaphorisch oder? da muss ich das doch echt teilen, und zwar auf rek. art bis die teilarrays neu noch die länge 1 haben und diese dann aufsummieren!

oder nicht?
 
S

SlaterB

Gast
wie jetzt, zuletzt schriebst du noch, du hättest 'nachgefragt'

die Aufgabe an sich sagt nix direkt darüber aus, was du machen sollt,
wenn man sie wörtlich nimmt kann man es so machen

den allgemeinen Erfahrungen bei solchen Formulierungen,
dem extrem richtungsweisenden Hinweis "zwei Parametern, die den linken und rechten Index des aufzusummierenden Bereichs",
und dem gesunden Menschenverstand (Berechnungsaufwand, Programmieraufwand, Nutzen) nach
ist die Sache eindeutig: nicht teilen

wie schon X-MAL GESAGT! ;)
noch mal von mir jedenfalls nicht ;)
 

Leroy42

Top Contributor
Um dem ganzen Heckmeck hier mal ein Ende zu bereiten:
Code:
	public static float sum(float[] floats) {return sum(floats, 0, floats.length-1);}
	public static float sum(float[] floats, int from, int to) {
		if (from>to)
			return 0;
		if (from==to)
			return floats[from];
		int mid = (from+to)/2;
		return sum(floats, from, mid)+sum(floats, mid+1, to);
	}
1. vielleicht lernt Gast ja durch Analysieren des Codes
2. Versuch mal, der Aufgabenstellung genau zu folgen: Also
Eine Klasse schreiben, die die floats als Instanzvariable besitzt und somit
die sum-Helper-Methode tatsächlich nur 2 Paramater benötigt (Anfang- und Endindex)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
R0m1lly Kombinationen aus int array rekursiv Java Basics - Anfänger-Themen 2
B Array nach Wert prüfen rekursiv Java Basics - Anfänger-Themen 5
O Enum Array Rekursiv abarbeiten Java Basics - Anfänger-Themen 44
B Fakultätsfunktion Rekursiv Berechnen aber mit Array Java Basics - Anfänger-Themen 10
B Fibonacci Zahlen rekursiv Array Java Basics - Anfänger-Themen 12
B Array rekursiv untersuchen Java Basics - Anfänger-Themen 21
G Rekursiv Array Elemente quadrieren Java Basics - Anfänger-Themen 2
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
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
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3
sserio Array funktioniert nicht Java Basics - Anfänger-Themen 2
sserio Iterierung über ein zweidimensionales Array Java Basics - Anfänger-Themen 16
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben