Darstellung einer dynamischen Matrix

Status
Nicht offen für weitere Antworten.

SebiB90

Top Contributor
Hi,

habt ihr eine Idee, wie man eine dynamisch erweiterbare Matrix erstellen kann? Ich brauch eigentlich ein 2d int array bei dem man Spalten und Zeilen hinzufügen kann.

Meine einzige Idee sind verschaltelte ArrayListen
Code:
ArrayList<ArrayList<Integer>> matrix = new ArrayList<ArrayList<Integer>>(5);
matrix.add(new ArrayList<Integer>(6));
//das ganze noch 4 weitere male

In einer Dimension diese Matrix zu erweitern wäre ja ganz einfach:
Code:
matrix.add(new ArrayList<Integer>(6));

allerdings wie kann ich die andere Dimension erweitern? Müsste dann ja jede Liste einzeln erweitern und das wäre schon umständlich =/

Hättet ihr eine Idee, wie man das einfacher realisieren könnte?

Danke im vorraus
SebiB90
 
S

Spacerat

Gast
Vllt. ein eindimensionales Array mit Zeilen * Spalten als Elemente. Dazu die Anzahl der Zeilen un Spalten zusätzlich speichern. Der Zugriff könnte dann schonmal mit Zeile * Zeilen + Spalte erfolgen. Die Erweiterung um eine Zeile ist dann im Prinzip kein Thema. Nur für ein performantes Hinzufügen von Spalten habe ich leider keine konkrete Idee.
 

0x7F800000

Top Contributor
könntest du bitte näher erläutern wozu du das brauchst bzw was du damit vorhast?
Bei dünnbesetzten matrizen könnte man je nach implementierung einfach neuen eintrag reinschmeißen und die zeilen/spalten ein wenig umbenennen, was sehr schnell gehen würde.
(Sowas hier: http://de.wikipedia.org/wiki/Compressed_Row_Storage könnte man leicht abwandeln, und schon würde es gehen)
Bei dicht besetzten matrizen ist ArrayList<ArrayList<X>> eine einigermaßen passable Lösung, allerdings musst du bei einfügen von Spalten ziemlich viel zeugs umkopieren, das dauert ewig.

Wenn du dichte matrix als eine Art "in zwei richtungen" verkettete Liste implementierst, dann hast du da zwar kein random access mehr, aber kannst die stets sehr schnell addieren und multiplizieren (bei einigen Algos könnte es aber ein ziemlicher krampf werden, hab's nie ausprobiert) und da könntest du sehr billig neue spalten und zeilen direkt an die richtige stelle einfügen.

Ist das wirklich nötig? Was willst du denn damit anstellen?
 

SebiB90

Top Contributor
Danke schonmal.
CRS sieht interessant aus. Allerdings ist die Matrix nicht unbedingt dünn(ab wann kann man überhaupt dünn sagen, wäre eine 50% befüllte Matrix noch dünn?) besiedelt, wobei sie je größer sie wird immer dünner besiedelt sein müsste.

Was ich eigentlich vor habe ist folgendes: Ich möchte einen Graph mit Mehrfachkanten darstellen. Da ich an beiden Enden der Kante eine Information(ein Integer Wert) brauche, nutze ich eine Inzidenzmatrix/Knoten-Kanten-Matrix ( http://de.wikipedia.org/wiki/Repräsentation_von_Graphen_im_Computer#Inzidenzmatrix ). Da der Graph erst im Programm aufgebaut werden soll vom Nutzer, brauch ich eine erweiterbare Matrix.
 
Zuletzt bearbeitet:

0x7F800000

Top Contributor
Üüüiii... :eek: ne, das kannst du glatt vergessen ;)
Zum einen sind Graphen bei allen möglichen Anwendungen eh tendentiell eher dünnbesetzt, zum anderen ist das mit "erweiterbarer matrix" unverhältnismäßig kompliziert, und imho auch unnötig. Verwalte das in einer Adjazenzliste, ist fast immer besser.
 

SebiB90

Top Contributor
Das Problem ist nur, dass ich bei Adjazenzliste nicht weiß, wie ich die Informationen an den Kantenenden speichern soll.
 

0x7F800000

Top Contributor
Was sind "Kantenenden"?
Ist doch vollkommen egal, wie das Objekt "Kante" aussieht. Du kannst da "Inhalt der kante" "Gewicht der Kante" "Ende der Kante" "Richtung der Kante" "7 kleine Füßchen der Kante" oder sonstwas dranhängen. Hauptsache die Kante wird aus dem Knoten verlinkt, statt einfach nur in eine Matrix eingetragen.
 

SebiB90

Top Contributor
Was sind "Kantenenden"?
Hm...nehmen wir mal eine Assoziation in einem UML Diagramm. Da kann man auch bei beiden Enden eine Multiplizität angeben. Und sowas meine ich. Also ich will kein UML darstellen, aber an einer Kante 2 Integer Werte speichern ;)

Hab grad vllt. ne Denkblokade und seh nicht wie man das bei einer Adjazenzliste macht =/
 
Zuletzt bearbeitet:

0x7F800000

Top Contributor
eine recht simple variante:
[HIGHLIGHT="Java"]
class Edge{
Node target; //wohin zeigt die Kante? (man kann auch beide Endknoten speichern)
EdgeData additionalInformation; //zum beispiel irgendein Tupel der unter anderem zwei int's enthält
}

class Node{
Collection<Edge> outcomingEdges;
NodeData additionalInformation;
}

/*
* "adjazenzliste" ist einfach nur eine collection von nodes, die wissen ja jeweils
* selbst wie sie untereinander verbunden sind
*/
Collection<Node> nodes=new LinkedList<Nodes>();
Node a=new Node(NodeData xyz);
Node b=new Node(NodeData zxy);
a.addEdge(/*wohin?*/b,/*zusatzinfos?*/123,789);
nodes.add(a);
nodes.add(b);
[/HIGHLIGHT]
du kannst dann natürlich noch die eingehenden kanten oder die Knoten von den die kante ausgeht mitspeichern, kommt drauf an ob man da in alle richtungen navigieren will, oder lauter nur "einbahnstraßen" braucht.

Und naja, wie gesagt... "Adjazenzliste" muss eigentlich keine Liste sein, und sie muss jetzt auch keine "Indizes" auf andere Knoten beinhalten, auch wenn Wikipedia das suggeriert. Es geht halt einfach darum, dass alles durch Referenzen verbunden wird, statt alle kanten in eine Matrix zu stopfen. Das ist so zu sagen die "natürlichere" Representation eines Graphen im Speicher.
 
Zuletzt bearbeitet von einem Moderator:

Marco13

Top Contributor
Ob die Knoten dann die Kanten "direkt" speichern sollten, ist eine andere Frage - man könnte auch ein interface machen, wo man sowas wie
Set<Edge> getOutgoingEdgesOf(Node node) { ... }
abfragt, und ob da dann eine Adjazenzliste oder eine Matrix dahintersteckt, ist egal.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Darstellung von Ergebnissen einer Dokumentensuche über eine JTable Allgemeine Java-Themen 19
D Problem bei der Darstellung einer trigonometrischen Funktion Allgemeine Java-Themen 2
E XML - Datei Darstellung in IntelliJ als Baum Allgemeine Java-Themen 2
G Darstellung von Text auf MapContext von GeoTools Allgemeine Java-Themen 2
Zrebna Alternative Darstellung eines Codesnippets Allgemeine Java-Themen 33
J Unicode Darstellung mit 5 chars Allgemeine Java-Themen 9
W Baumstrukturmodell -> Darstellung als TreeView Allgemeine Java-Themen 5
I Fehler bei HashMaps Darstellung Allgemeine Java-Themen 10
krgewb Darstellung bei Java-Update Allgemeine Java-Themen 8
O Darstellung von else if anweisung im struktogramm? Allgemeine Java-Themen 1
F Framework/Plugin für Tree-Darstellung in Graph Allgemeine Java-Themen 0
N Best Practice Flexible String-Darstellung Allgemeine Java-Themen 1
R Bibliothek für Darstellung von char auf 5x7 Dot-Matrix Allgemeine Java-Themen 2
G REST- Object darstellung Allgemeine Java-Themen 6
K Javamail:Probleme mit der Darstellung von Umlaute in Subject Allgemeine Java-Themen 15
O Problem bei Darstellung der Laufzeit eines Programms Allgemeine Java-Themen 3
C Swing JComboBox - Problem mit der Darstellung des Inhaltes Allgemeine Java-Themen 9
I Teilweise falsche Darstellung jap. Zeichen im JEditorPane mit RTFEditorKit aus RTF-Datei Allgemeine Java-Themen 5
B Darstellung bei verschieden win Systeme spinnt! Allgemeine Java-Themen 2
C Darstellung der Liste bei vielen Daten extrem langsam Allgemeine Java-Themen 11
X CATIA Konstuktionsdaten Import- Darstellung Allgemeine Java-Themen 4
J Encoding und Gewinnung von Zeichen aus der Hexa-Darstellung Allgemeine Java-Themen 6
GilbertGrape Darstellung wie in einem Diff-Programm Allgemeine Java-Themen 8
E Hexa-Darstellung Allgemeine Java-Themen 5
M Darstellung von Brüchen Allgemeine Java-Themen 3
B Darstellung von Objekten dauern unterschiedlich lang ! Allgemeine Java-Themen 5
H Unicode Darstellung in Java, spezielles Zeichen gesucht Allgemeine Java-Themen 4
D Double: Grenzen und Darstellung Allgemeine Java-Themen 7
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5

Ähnliche Java Themen

Neue Themen


Oben