Doppelt verkettete Liste sortieren?

  • Themenstarter Fragender_Johnny
  • Beginndatum
Status
Nicht offen für weitere Antworten.
F

Fragender_Johnny

Gast
Wir haben hier das Problem, dass wir doppelt verkettete Liste aus Objekte, welchen CD-Alben darstellen sollen, und diese nach ihrem Ranking (int Wert) sortieren sollen. Problem ist, dass das vertauschen, die Liste zerstört.

So sieht unser Code bis jetzt aus:

Code:
 public void SORTBY_RATING()
  {
    Album album1 = head;
    Album album2 = album1.next;
    Album temp;
    boolean getauscht;
    
    if(album1.next==null)
    {
      System.out.println("Keine Sortierung, da nur ein Album !");
      return;
    }

   while(album2!=null)
   {
   getauscht=false;
   System.out.println("*****"); //wurde von einem Moderator zensiert!
     while (album2!=null && album1.bewertung < album2.bewertung)
    {
    System.out.println("*****"); //wurde von einem Moderator zensiert!

    album1.next=album2.next;
    if(album2.next!=null)
      {
      album2.next.prev =album1; //!!! evtl null
      }

    album2.prev= album1.prev;
    if(album1.prev!=null)
      {
      album1.prev.next=album2;
      }

      album2.next=album1;
      album1.prev=album2;
      album2=album1.next;
      getauscht=true;
    }
     if(getauscht==false)
     {
     album2=album2.next;
     album1=album2;
     }
   }
  }

Wäre für jeden Tipp dankbar!

MFG

Dieser Beitrag wurde von L-ectron-X am 07.06.2007 um 10:09 Uhr editiert/zensiert.
Bitte Forumreglen beachten!
 
S

SlaterB

Gast
male doch auf einen Blatt Papier rum,
kleistere dein Programm mit System.out.println zu, um zu sehen, was in einem speziellen Testfall ganz genau passiert,
das ist eine so schön einfache übersichtliche Sache, später wirst du ganz andere Probleme haben..

-------

die erste Zeile ist schon das Ende vom Lied:
album1.next=album2.next;

was vorher in album1.next war, ist für immer verloren,
die Variable ist überschrieben..
 
F

Fragender_Johnny

Gast
sitz grad noch an der uni und muss das teil morgen haben, kann mir bitte jemand den code editieren das er funzt! Wär sehr wichtig! Vielen vielen Dank schonma!

MFG
 
G

Gast

Gast
Erstens: Schämst du dich nicht sowas zu posten? (Siehe Zeile 17 u. 20)
Zweitens: nimm doch einfach eine ArrayList und schreib dir einen entsprechenden comparator oder implementier comparable.Oder darfst du das nicht verwenden...
 

nebulo

Bekanntes Mitglied
Es scheint zwar inzwischen niemanden mehr zu interessieren. Aber eigentlich sollten sämtlich in-place Sortierverfahren also auch Bubble-Sort kein Problem darstellen.

Ich verstehe nicht was das Problem ist.

Wenn noch Interesse besteht bitte konkret nachfragen was das Problem ist. Wer hier ohne nachzudenken nach einer Lösung will wird selten eine bekommen!
 
K

k.

Gast
hm, komischerweise müssen wir das selbe machen, haben aber bis zum 13.6. dafür zeit. sogar die Namen stimmen überein....
erstmal: SORTBY_RATING soll ein Integer sein (Stichwort "static final").
an den while schleifen zum passenden durchlauf bastel ich auch noch, aber hier mal meine swap-methode, die 2 albümer die nebeneinander liegen vertauscht
Code:
/**
	 * Tauscht zwei benachbarte Albümer aus
	 * @param a1 Album das nach hinten rutscht
	 * @param a2 Album das nach vorne kommt
	 */
	public void swap( Album a1, Album a2 )
	{
		Album a1vorgaenger = a1.getPrev();
		Album a2nachfolger = a2.getNext();
		
		a1.setPrev( a2 );
		
		if (a2nachfolger == null)
		{
			a1.setNext( null );
			tail = a1;
		}
		else
		{
			a1.setNext( a2nachfolger );
			a2nachfolger.setPrev( a1 );
		}
		
		if (a1vorgaenger == null)
		{
			a2.setPrev( null );
			head = a2;
		}
		else
		{
			a1vorgaenger.setNext( a2 );
			a2.setPrev( a1vorgaenger );
		}
		
		a2.setNext( a1 );
	}
ansonsten viel spaß noch beim tüfteln....
 
R

railbird

Gast
komischerweise muss ich genau das gleiche auch machen. hab auch bis 13.6. zeit
 
G

Guest

Gast
Dito :)

Aber auch bei mir läuft noch nicht Alles ....

Hat jemand z.B. eine Idee wo der Haken hier ist bzw. was falsch ist, der gute algorithmus verfällt manchmal , nicht immer in eine scheinbare endlosschleife...



Code:
public void setSortMode(int Sort){
   ListNode n = head;
   actSort = Sort;
    ListNode temp;

     if (actSort == 1){
      unsorted = true;

      while (unsorted && n!= null){
           while (n.next != null){
              while(n.Inhalt.compAlb_I(n.next.Inhalt, n.Inhalt)){
                   temp = n;
                   n = n.next;
                   n.next = temp;
                }
             n = n.next;
                  //Zeiger auf nächstes Album
            }
        unsorted =false;
       }
     }
    if (actSort == 2){
      unsorted = true;

      while (unsorted && n != null){

          while (n.next != null){
               while (n.Inhalt.compAlb_B(n.next.Inhalt, n.Inhalt)){
                   temp = n;
                   n = n.next;
                   n.next = temp;
                }
                n = n.next;   //Zeiger auf nächstes Album
            }
        unsorted = false;
       }
    }


  }
 
S

SlaterB

Gast
Tipp: verwende nur eine Schleife und mache in der Mitte

compare = 0;
if (actsort = ..)
compAlb_I
else
compAlb_B

--------

> temp = n;
> n = n.next;
> n.next = temp;

temp.next ist dann der Vorgänger von temp, nämlich n, wie es schon immer war?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Z Sortiertes Einfügen in doppelt verkettete Liste Allgemeine Java-Themen 5
R doppelt verkettete Liste: Fehler beim Einfügen Allgemeine Java-Themen 3
chik Doppelt verkettete Liste bzw. Zirkulärliste (kleiner Fehler, den ich nicht finde) Allgemeine Java-Themen 4
J Doppelt verkettete Liste Allgemeine Java-Themen 6
M doppelt verkettete Listen Allgemeine Java-Themen 2
L Doppelt Verkettete Listen Allgemeine Java-Themen 6
M doppelt verkettete Listen? Allgemeine Java-Themen 5
N warum wird es doppelt ausgegeben Allgemeine Java-Themen 6
P Erstelltes Programm ist doppelt so groß Allgemeine Java-Themen 11
S If-Menü wird doppelt ausgegben Allgemeine Java-Themen 4
D "Paste" String doppelt Allgemeine Java-Themen 14
D Methoden Buttons erscheinen doppelt nach Wiederholung in Schleife Allgemeine Java-Themen 1
Sin137 Interface Eingabe wird doppelt angezeigt Allgemeine Java-Themen 2
O Sax-Parser ließt XML-File doppelt Allgemeine Java-Themen 1
J Fragen zu generischer doppelt verketteter Liste (bei fehlendem Grundverständnis) Allgemeine Java-Themen 1
N Fehler abfang läuft doppelt durch Allgemeine Java-Themen 2
ARadauer Random keine Zahlen doppelt Allgemeine Java-Themen 4
M Alles doppelt in Eclipse syntaxhilfe Allgemeine Java-Themen 6
C Vier Stellen Keine Doppelt (Zufall) Allgemeine Java-Themen 20
G Array doppelt verkettet? Allgemeine Java-Themen 6
L doppelt gelinkte liste /getFirst/removeFirst/clear/Remove Allgemeine Java-Themen 2
S Thread wird nach erneutem Instanzieren doppelt gestartet!? Allgemeine Java-Themen 4
I Doppelt verkette Listen Allgemeine Java-Themen 2
M einfach verkettete Liste verstehen Allgemeine Java-Themen 23
K verkettete Liste Allgemeine Java-Themen 3
OSchriever Einfach verkettete Liste ändern Allgemeine Java-Themen 43
K Einfache Verkettete Liste mit Node Allgemeine Java-Themen 3
S Verkettete (Teil)Liste sortieren ( rekursiv bis n) Allgemeine Java-Themen 2
T Verkettete Suche Allgemeine Java-Themen 6
J Rekursion oder Iteration - verkettete Listen Allgemeine Java-Themen 8
L verkettete Listen oder Arrays + Indexlisten effizienter? Allgemeine Java-Themen 3
D Einfach verkettete Liste Allgemeine Java-Themen 3
X einfach verkettete Liste und Insertion Sort Allgemeine Java-Themen 3
R Verkettete Liste Allgemeine Java-Themen 5
E Verkettete Listen Allgemeine Java-Themen 5
M Schlange als verkettete Liste Allgemeine Java-Themen 4
MiMa Filtern von TableView Liste Allgemeine Java-Themen 2
B Liste aller Kombintionen mit Einschränkungen Allgemeine Java-Themen 8
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Liste ändern während Iteration über Diese? Allgemeine Java-Themen 16
D Erste Schritte Liste erweitern Allgemeine Java-Themen 11
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
L allgemein Strings händisch in Liste sortieren Allgemeine Java-Themen 47
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
Gaudimagspam Skip Liste erstellen in Java Allgemeine Java-Themen 3
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
bueseb84 Spring Boot Entity mit Liste Allgemeine Java-Themen 4
MiMa Werte in liste speichern? Allgemeine Java-Themen 3
Curtis_MC Collections Liste anhand mehrere Kriterien sortieren Allgemeine Java-Themen 6
G Liste (UsageStats) sortieren (Android) Allgemeine Java-Themen 5
T Google Links in einer Liste Allgemeine Java-Themen 4
looparda Liste filtern nach Prädikaten verschiedener Typen Allgemeine Java-Themen 3
L Liste überschreibt alte Elemte Allgemeine Java-Themen 10
H Länge einer verketteten Liste Allgemeine Java-Themen 4
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
S Methoden Liste soll Methode aus innerer Klasse aufrufen Allgemeine Java-Themen 4
L Erste Schritte Liste von Datums filter nach Monate Allgemeine Java-Themen 4
Y Liste in Stream Packen Allgemeine Java-Themen 1
perlenfischer1984 Reflection : Element in generische Liste hinzufügen Allgemeine Java-Themen 4
perlenfischer1984 Liste mit generics zurück liefern Allgemeine Java-Themen 8
G Liste zwischen zwei Kalenderdaten erstellen Allgemeine Java-Themen 3
B Wie vergleiche ich Strings in einer Liste? Allgemeine Java-Themen 5
Viktim Threads Liste In unterschiedlichen Threads bearbeiten Allgemeine Java-Themen 23
A Collections Inhalt einer Liste mit Inhalt anderer Liste vergleichen ? Allgemeine Java-Themen 7
I Abstrakte Datentypen - Liste Allgemeine Java-Themen 9
D Datentypen Klassenattribut aus Objekt in generischer Liste Allgemeine Java-Themen 15
P Liste zu Objekt umwandeln Allgemeine Java-Themen 4
Z In die Liste kann ich nichts adden Allgemeine Java-Themen 16
C Liste checken auf MINDESTENS ein Objekt | Bukkit Allgemeine Java-Themen 3
M liste von listen anders ausgeben Allgemeine Java-Themen 1
B Per Buttonklicks einer Liste Wörter hinzufügen - Wie umsetzen? Allgemeine Java-Themen 11
H Liste sortieren anhand optionalem Property Allgemeine Java-Themen 3
L Liste führt sich nicht weiter Allgemeine Java-Themen 5
A Input/Output Liste der Dateien in einem Ordner in einer Jar Datei erhalten Allgemeine Java-Themen 11
B Prüfen, ob ein Element in der Liste nicht existiert Allgemeine Java-Themen 3
B Klassen JTable mit einer Liste Allgemeine Java-Themen 0
X HTTP Auslesen der Ergebnisse von einer Webseite und in eine Liste packen Allgemeine Java-Themen 1
A Auslesen einer Datei sowie ausgeben als Liste in App Allgemeine Java-Themen 5
E Liste löscht sich selbstständig Allgemeine Java-Themen 5
H Liste von Objekten generisch sortieren Allgemeine Java-Themen 0
D Liste anhand Standardnormalverteilung befüllen Allgemeine Java-Themen 1
M Threads synchroner Zugriff (add/delete/read) auf eine Liste Allgemeine Java-Themen 6
T Datentypen Eine Liste - verschiedenen Klassen - eine Abstracte Klasse Allgemeine Java-Themen 3
M Werte aus DB in Liste speichern ohne mehrfach speicherung Allgemeine Java-Themen 18
G Liste anzahl der gleichen Objekte Allgemeine Java-Themen 6
S Pattern.Match Suche: For Schleife einbinden und in Liste schreiben Allgemeine Java-Themen 3
O aus Liste ein beliebiges Element auswählen Allgemeine Java-Themen 7
J Liste aller Com-Ports - zweistellige Ports? Allgemeine Java-Themen 15
O MVC - wo Liste der ComboBox-Items ermitteln Allgemeine Java-Themen 3
MiMa Liste von Pfaden in eine textArea schreiben Allgemeine Java-Themen 7
K kontinuierlich aktuelle Bestellsystem-Liste mit farbigem Status Allgemeine Java-Themen 2
A Auswählbare Liste Allgemeine Java-Themen 2
D Sortieren von Liste zu unperformant Allgemeine Java-Themen 6
N Liste gesucht Allgemeine Java-Themen 2
S Probleme beim Auslesen einer Liste Allgemeine Java-Themen 8
O JSON String bauen aus Liste Allgemeine Java-Themen 2
M Über Liste verschiendene JComponents mit eigenem implementierten Interface ansprechen Allgemeine Java-Themen 7
T Hashmap mit geordneter/ungeordneter liste als Value Allgemeine Java-Themen 5
D Zugriff auf Array-Liste Allgemeine Java-Themen 19

Ähnliche Java Themen

Neue Themen


Oben