Java Linked List

Status
Nicht offen für weitere Antworten.

KalleWirsch

Aktives Mitglied
Hi,

also eigentlich will ich mit bubbleSort eine verlinkte Liste sortieren! Gut die Laufzeit ist zwar schlecht aber ich wüsste jetzt keinen Suchalgorithmus der schneller ist und Listen sortiert!!

...
Ich habe ein Problem wenn ich bei der doppelt verketteten Liste zwei Elemente vertauschen will.
Irgendwie klappt es nicht, wenn ich das Element 2 ausgehängt habe dieses dann vor das Element 1 zu hängen.
Wie ich El.1 mit El.3 verbinde weiß ich ... es funktioniert auch!!

Hier hab ich meine Methoden
Code:
public Datum GetPrevious()
	    {
	    	return previous;
	    }
	    
	    auf p
	    public void SetPrevious(Datum p)
	    {
	    	previous = p;
	    }
	        
	    
	    public Datum GetNext()
	    {
	    	return next;
	    }
	    
	   
	    public void SetNext(Datum n)
	    {
	    	next = n;
	    }
so hänge ich das Element aus:

Code:
  Datum d = GetFirst();
  Datum next = d.GetNext();
  d.SetNext(next.GetNext());
  next.GetNext().SetPrevious(d);


hiermit versuche ich dann das Element ganz vorne anzuhängen

Code:
  d.SetPrevious(next);
  next.SetNext(d);

aber wenn ich mir später die Liste in einer Schleife ausgeben lasse zeigt er mir das Element nicht mehr an!!1


weiß vielleicht jemand was ich da machen könnt???

mfG
Alpee
 
B

Beni

Gast
Merkst du dir auch, dass du einen neuen Start für die Liste hast?
 

Leroy42

Top Contributor
d = GetFirst(); ==> d ist ein Element
next = d.GetNext(); ==> next ist das Folgeelement von d
d.SetNext(next.GetNext()); ==> d's Folgeelement wird auf next's Folgeelement gesetzt
next.GetNext().SetPrevious(d); ==> Das Vorgängerelement des Nachfolgers von next wird auf d gesetzt.

:autsch:


Edit: (Bis dahin scheint es ja doch in Ordnung zu sein)

Beschreib erstmal welche Elemente vertauscht werden sollen :shock:
- d und sein Nachfolger?
- d und sein Vorgänger?
- ...

Dann können wir dir helfen
 

KalleWirsch

Aktives Mitglied
es soll eiegntlich d mit seinem Nachfolger vertauscht werden!!!

Meine Idee ist:
das Nachfolgeelement von d auszuhängen
d an das übernächste Element zu hängen
und dann das ehemalige Nachfolgelement von d (dass ausgehängt wurde) vorne, vor d zu hängen!
 

KalleWirsch

Aktives Mitglied
oh sorry ... ich merk grad, vielleicht ist meien Überschrift falsch!!!
Sie sollte wohl besser doppelt verkettete Liste heißen!!
 

KalleWirsch

Aktives Mitglied
also in meien Methoden umgeformt, müsste das doch so aussehen:

Code:
	    	Datum n = d.GetNext();

	      	n.GetNext().SetPrevious(n);
	      	d.GetPrevious().SetNext(n);
	      	n.SetPrevious(d.GetPrevious());
	      	n.SetNext(d);
	      	d.SetNext(n.GetNext());
	      	d.SetPrevious(n);

nun bekomme ich aber eien Meldung, dass irgendwo ein NullPointer entsteht

Exception in thread "main" java.lang.NullPointerException
at five.Liste.BubbleSort_Par(Liste.java:281)
at five.Liste.main(Liste.java:19)


irgendwie versteh ichs nicht :bahnhof:
 

KalleWirsch

Aktives Mitglied
ich hab meinen Fehler jetzt doch endlich gefunden ...
ich hatte vergessend er Liste zusagen, dass sie einen neuen Anfang hat ???:L


danke für die Hilfe!!!

mfG!
 

KalleWirsch

Aktives Mitglied
Noch eine Frage:


Wenn ich also 3 Elemente habe ... El 1 - El 2 - El 3 die sind doppelt verkettet.
jetzt vertausche ich El1 mit El 2 --> El2 - El1 - El3.
Jetzt sage ich El2 das es der Anfang der Liste ist also head = El2
weshalb bekomme ich dann nicht 'null' geliefert wenn ich El2.previous abfrage??




Code:
    d.SetNext(next.GetNext()); 
    next.GetNext().SetPrevious(d); 
    d.SetPrevious(next); 
    next.SetNext(d);     
    SetFirst(next); // Hier sage ich next das es der Kopf der Liste ist
    //System.out.println("Check ob null: " + next.GetPrevious());
    d= GetFirst(); // nun wir d der Kopf also praktisch d= next
    System.out.println("Check whatz Previous: " +(j+1)+" "+ d.GetPrevious());


wenn ich d.prev abfrage bekomme ich immer das Element gekliefert das vorher davor angehängt war.
Wenn man die Zeiger verschieb ... behält sich Java das dann??


mfG
 
S

SlaterB

Gast
solange du eine Referenz nicht auf null setzt oder auf was anderes,
solange wird auf das vorherige Objekt gezeigt,
kann dann auch nicht zerstört werden oder ähnliches
 

KalleWirsch

Aktives Mitglied
irgendwie steh ich MEGA aufm Schlauch ...

also ich will ja mit nem Bubblesort meine doppelt verkettete Liste sortieren

Code:
public void bubbleSort_Par()
	    {
	      	int length = length();
	      	Datum d = getFirst();
	      	Datum next = d.getNext();
	      	int j=0;
	      	next.setPrevNull();
	      	
	      		while(j < length)
	      		{                /*Hier vertausche ich alle elemente bis auf das letzte*/
			      	if (d.Par_ID() > next.Par_ID() && next.getNext() != null )
		      		{
		      		    d.setNext(next.getNext()); 
				    next.getNext().setPrevious(d); 
				    d.setprevious(next); 
				    next.setnext(d);
				    setfirst(next); /* klar hier wird dann immer das aktuelle Element als head gemacht ... aber wenn ich das nicht so mache bekomme ich die Elemente, die nach head kommen nicht mehr angezeigt*/
				    d= getFirst();
		      		}

                                                                /*hier wird das letzte Element vertausch*/
			      	else if (d.Par_ID() > next.Par_ID() && next.getNext() == null )
			      	{
			      		next.setNext(d);
			      		d.setPrevious(next);
			      		next.setPrevious(d.getPrevious());
			      		setLast(d);
			      	}

	      		//hier wird der aktuelle ptr je eins weiter geschickt
	      		d = d.getNext();
	      		if (next.getNext() != null)
	      		{
	      			next = d.getNext();
	      		}
	      		
	      		j++;

	    }// Ende while Schleife

aber irgendwie bekomm ichs nicht hin.
Einmal weiß ich nicht wie ich den Anfang der Liste setzten soll und zum andern mal klappt es nicht wenn, ich das letzte Element mit dem vorletzten vertauschen will!!!

vielleicht hat ja jemand Tips wie ich meinen Code auf die Richtige Reise bringe.
...
@SlaterB so richtig klappt das nicht die Referenzen auf null zu setzten... Ich kann sie ja nur über Methoden ansprechen und dann zeigt er mir NullPointer Exceptions an ... gibt es da irgend einen Trick???


meine zusätzlichen Methoden:

Code:
	    public Datum setLast(Datum f)
	    {
	    	return tail = f;
	    }

                    public void setPrevNull() 
	    {
	    	previous = null;
	    }
	    
	    public void setNextNull()
	    {
	    	next = null;
	    }
Mit setPrev- NextNull will ich bezwecken, dass einem Pointer einen Nullwert geben kann

Code:
	    public Datum setLast(Datum f)
	    {
	    	return tail = f;
	    }
 
S

SlaterB

Gast
> @SlaterB so richtig klappt das nicht die Referenzen auf null zu
> setzten... Ich kann sie ja nur über Methoden ansprechen und dann
> zeigt er mir NullPointer Exceptions an ... gibt es da irgend einen Trick???

auf ungenaue Beschreibungen kann man nix gescheites antworten,
sowas wie
Code:
       public void SetNextNull()
       {
          next = null;
       }
für previous wäre doch nicht schlecht,

dann würde bei
Code:
d= GetFirst(); 
d.SetPreviousNull();
System.out.println("Check whatz Previous: " +(j+1)+" "+ d.GetPrevious());
gerantiert null als previous kommen,
und wo soll da eine NullPointerException auftrefen, solange nicht d selber null ist?

ich kann also mit deiner Nachfrage gar nix anfangen

----------

wenn du dich an Java-Konventionen halten würdest, z.B. alle Operationen klein schreiben!,
dann wäre dein Code viel besser lesbar, dann würden vielleicht mehr Leute mit reinschauen,

ich erspare mir jedenfalls, die 40 Zeilen-while-Schleife durchzuarbeiten solange da alles kryptisch ist


falls du eine Überarbeitung vornimmst, dann denke doch bitte auch gleich noch an die Einrückungen,
manche sind 2 Zeichen, andere riesige Tabs, manchmal ist gar keine Einrückung..
Kommentare fliegen durch die Luft..,

benutze die Vorschau bzw. die Edit-Funktion und bedenke:
wichtig ist nicht wie es in deinem Texteditor aussieht,
sondern wie es im Forum aussieht
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
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
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben