Array vergrößern

Status
Nicht offen für weitere Antworten.
Ich muss für die aktuelle Programmieraufgabe von Informatik I Daten in ein Array schreiben, jedoch weiß ich nicht, welche Menge Elemente benötigt werden, wenn ich das Array anlege.

Also muss mein Array erweiterbar sein, mit jedem neuen Element also um eins wachsen.

Ich habe mir nun folgendes überlegt: Ich erzeuge mir ein Array der Größe 1, in das ich das erste Element speichere. Bei jedem weiteren Durchlauf erzeuge ich ein Array der Länge altesArray.length+1 und kopiere das eine Array in das andere.

Jedoch scheint mir das in Bezug auf Laufzeit/Speicherplatz nicht sonderlich gut. Gibt es eine andere/bessere Möglichkeit?

ArrayList etc dürfen wir NICHT benutzen ;) ;(
 
B

bygones

Gast
wenn du davon ausgehen kannst. dass so und so mehrmals der Array erweitert wird kannst du natuerlich auch einen anderen Faktor als 1 nehmen....
 
wenn du davon ausgehen kannst. dass so und so mehrmals der Array erweitert wird kannst du natuerlich auch einen anderen Faktor als 1 nehmen....
Naja, jedoch kann es sein, dass nur ein Element ins Array soll, es kann aber auch sein, das 20.000 Elemente sein sollen (eigentlich weiß ich ja, dass 4480 Elemente rein sollen, nur laut unseren Übungsleitern soll das ganze auch für mehr/weniger Elemente funktionieren ;) )!
 

Leroy42

Top Contributor
Arrays kann man nicht vergrößern!

Aber anstatt dein Ansatz, nur jeweils in ein um ein Element
größeres Array zu kopieren ist wirklich ineffizient.

Bastele dir doch deine eigene kleine Klasse die sich
an ArrayList orientiert.

Sie sollte eine Instanzvariable size enthalten die die aktuell
zu verwendende Größe des intern verwalteten Arrays angibt,
bei jeder Erweiterung die Größe des internen Arrays verdoppelt
und zum Beispiel mit einer initialen Größe des internen Arrays von 10 ausgeht!
 

Der Müde Joe

Top Contributor
ArrayList macht so:

default 16
wenn zu klein: verdoppeln (Arraycopy)

kannst auch eine init grösse wählen.
wenn zu klein: verdoppeln

Die Spezialfälle darfst du gerne im Source angucken ;-)
 
Hmm... klingt gar nicht so verkehrt die Idee (bis auf die Tatsache, dass es sicherlich viel Arbeit ist^^). Werde mir jetzt gleich mal die Klasse ArrayList anschauen und gucken, was die so tolles kann bzw was ich davon brauch und nachprogrammieren muss =)
 

sayang

Aktives Mitglied
Ich denke mal (oder besser: ich hoffe mal), den Aufgabenstellern ist schon bewusst, dass es bessere Möglichkeiten einer "verlängerbaren" linearen Datenstruktur gibt. "Informatik I" klingt für mich eher danach, dass der Schwerpunkt hier auf der Übung des Array-Handlings an sich und der Übung im Umgang mit simplen Konstrukten wie for-Schleifen o.ä. liegt. Wenn ich Zwergpintscher beim Wort nehme, sollen die Elemente in ein "Array" - also nicht in eine List oder Map oder Table oder sonstwas - geschrieben werden.

Insofern ist der Ansatz ja nicht verkehrt, wenn auch ineffizient.
Ich würde vielleicht ein Array mit 1000 Feldern anlegen und auch immer wieder um 1000 vergrößern.
Nachdem das letzte Element in das Array gelegt wurde, würde ich dann die Länge des Arrays wieder soweit verkleinern, dass die Anzahl der Felder genau der Anzahl der Elemente entspricht.

Klar kann man die Verwaltung dieses Arrays in eine eigene Klasse schreiben - man muss nur eben in dieser Klasse ein Array als Datenstruktur benutzen.

Lg
sayang
 
Ja, es geht darum, dass wir uns selber mit den Datenstrukturen auseinandersetzen und nicht einfach ArrayList nehmen.
Ne andere Möglichkeit wäre auch eine verkettete Liste, die man implementieren könnte, allerdings mochte ich damals die Übungen mit den Listen schon nicht und will deswegen erstmal das mit nem Array zu machen- zumal anschließend die Elemente sortiert werden sollen und ich (als Java-Anfänger) denke, dass es einfacher ist den Sortier-Algorithmus für Arrays umzusetzen als für eine verkettete Liste ;)
 

Der Müde Joe

Top Contributor
>dass es bessere Möglichkeiten einer "verlängerbaren" linearen Datenstruktur gibt.

und wenn du jetzt den Blickpunkt auf RandomAccess richten würdest ;-)
 
So, ich habs jetzt einfach gemacht, dass ich das Array immer vergrößer ;) Sicher keine optimale Lösung, aber läuft einwandfrei und ging am schnellsten!

Danke allen für die Tips :)
 
Ja, aber man folgendes kann man machen:
Java:
	//Kopiert ein Array in ein neues Array, welches ein Element groesser ist
	public static Int[] arrayCopyGroesser(Int[] alt)	{
		Int[] neu = new Int[alt.length+1];
		
		for (int i=0; i<alt.length; i++)	{
			neu[i]=alt[i];
		}
		
		return neu;
	}//ENDE arrayCopyGroesser
 

Ark

Top Contributor
Ich antworte mal nur auf den Code hier, kenne das umgebende Problem nicht.

Wenn ich richtig informiert bin, verdoppelt z.B. ein StringBuilder seine Kapazität, wenn die alte überschritten wird. Ich denke, das hat etwas mit der Komplexität zu tun. Bei sukzessivem Anhängen einzelner Zeichen wächst so die Kapazität exponentiell, während diese Vergrößerung selbst nur noch logarithmisch oft (<-- mir fällt dafür gerade kein besserer Ausdruck ein) vorgenommen wird. Betrachtet man beide Umstände zusammen, ergibt sich so nur etwa linearer Aufwand. Da aber das Umkopieren nur noch logarithmisch oft geschieht, wird dieses zu noch erträglichem, wenn nicht sogar vernachlässigbarem Aufwand, während die gerade beschriebene Variante, ein Array nur um ein einziges Element "wachsen" zu lassen, zu (halb-)quadratischer Komplexität führt.

Ark
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
O Array verkleinern, vergrößern Java Basics - Anfänger-Themen 1
T Array vergrößern Java Basics - Anfänger-Themen 6
C Array vergrößern? Java Basics - Anfänger-Themen 8
G zweidimensionales Array vergrößern Java Basics - Anfänger-Themen 3
D Array vergrößern Java Basics - Anfänger-Themen 7
B Array im Nachhinein vergrößern? Java Basics - Anfänger-Themen 3
G array vergrößern Java Basics - Anfänger-Themen 3
A Zeichenkette teilen mit Substring oder Char Array Java Basics - Anfänger-Themen 14
A 6. Element aus einem Array zurückgeben Java Basics - Anfänger-Themen 1
A Was bedeutet bei einem Array "int a [MAX][MAX];", Java Basics - Anfänger-Themen 7
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
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
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

Ähnliche Java Themen

Neue Themen


Oben