Zum Inhalt springen

Probleme mit Vektoren


Silizium185

Empfohlene Beiträge

Halli Hallo

ich hab da ein kleines Problem mit Vektoren.

Eine Aufgabe lautete, dass wir unsere eigene Vektorklasse schreiben sollten, was ich auch gemacht habe. Diese funktioniert auch.

Als Zusatzaufgabe gilt:

Testen Sie, ob nach mehreren push_front Aufrufen der

Methodenaufruf get(0) das letzte mit push_front eingefügte Element

zurückliefert.

Die Push_front Methode startet beim Array von der Position 0 und springt nach jedem Element Eintrag um eine Position weiter.

Wenn ich aber die get(0) Methode aufrufe, bekomme ich immer nur das Element an der Position 0. (was ja irgendwie auch logisch ist*g*)

Wie kann ich das Problem lösen?? Hatte mir schon überlegt, dass ich nach jedem Vorgang die gesamten Arrayeinträge um eins verschiebe, so dass die Position 0 wird frei zum belegen wird. Aber das wäre auf Dauer ein riesen Aufwand.

Na vlt fällt euch was schönes ein ;-)

Schonmal danke

Link zu diesem Kommentar
Auf anderen Seiten teilen

Was sollst Du genau machen, denn für mich hört sich die Beschreibung nicht nach Vektoren (im mathematischen Sinn) an, sondern nach einen Stack. Java bietet generell schon für das Problem fertige Strukturen an, wenn man so etwas selbst implementieren will, dann sollte man auf das Collection-Interface zurückgreifen

Link zu diesem Kommentar
Auf anderen Seiten teilen

es geht ja auch nicht um die mathematischen Vektoren. Sondern um die Vektoren in Java ;-) Also ein Array ist voll, alles wird in ein größeres neues Array kopiert.

Da ich erst heute Stacks kennengelernt habe und die Aufgabe von letzter Woche ist, gehe ich davon aus, dass es irgendwie eine Lösung mit Vektoren geben muss.

Was ich machen muss:

Ich füge ein Element ein. Das Element ist dann auf der Position 0. Füge ich ein weiteres Element ein, so ist es an der 1. Position. Jetzt übergebe ich den Index 0 an meine get Methode, die daraufhin mir Element an der 0. Position zurück gibt.

Aufgabe ist es jetzt, dass ich mit dem get(0) Aufruf immer das letzte hinzugefügte Element bekomme.

Als Beispiel: Ich füge an der Stelle 0 die Zahl 5 ein. Rufe ich get (0) bekomme ich 5.

Danach füge ich die Zahl 7 ein. Jetzt soll ich mit der get (0) die 7 bekommen und da scheitert es bei mir.

Hoffe ich konnte mein Problem bissel besser darstellen

Link zu diesem Kommentar
Auf anderen Seiten teilen

Also ich denke, Sinn der ganzen Übung wird es nicht sein, einfach die Vector-Klasse zu benutzen - zumindest aus pädagogischer Sicht nicht. Es geht wohl darum, dass der TO anhand seines aktuellen Wissenstandes versuchen soll, eine eigene Vector-Klasse, vielleicht inspiriert durch die C++-Klasse Vector<> zu erstellen. Zentrale Probleme sind also: a) wie managed man die Größe, die ja dynamisch, bzw. flexibel gehalten werden soll und B) wo ist bei der Liste "vorn" und "hinten" und wie füge ich da was ein und bekomme entsprechend auch wieder etwas heraus. Das ganze läuft wahrscheinlich auf soetwas wie einen internen Cursor der Vektorklasse raus, mit welchem realisiert wird, wo gerade "vorne" ist, bzw. und wo dann von da aus das nte Element zu finden ist.

Link zu diesem Kommentar
Auf anderen Seiten teilen

Der OP beschränkt sich ja bisher auf Arrays, das sind immer noch statische Datenstrukturen. Jede dynamische Struktur lässt ohne Pointer direkt in Java abbilden, auch ohne Arrays. Das Post bezieht sich auf die Vektoren in Java, also wäre das wohl der Startpunkt. Natürlich kann man aus pädagogischer Sicht eine eigene templatebasierte (generic) Vektorklasse in Java entwickeln. Dazu wären wohl einfach- bzw. doppeltverkettete Listen ein erster Ansatz

Link zu diesem Kommentar
Auf anderen Seiten teilen

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...