ArrayList Elemente verknüpfen

locolukas

Mitglied
Hallo Gemeinde,

ich arbeite im Moment spasseshalber an einem Algorithmus der Zahlen in einer ArrayList sortiert.
Mich interessert vor allem wieviele Versuche man braucht und wie man einen Standard Algorithmus möglichst perfomant machen kann ohne auf BubbleSort o.ä. zurückgreifen zu müssen.
In einfacher Form funtioniert das ganze schon, und zwar so:
Die gemischte List wird bottom-up durchlaufen indem einzelen Zahlen verglichen werden bis die höchste Zahl am Ende oben liegt. Diese muss nun nichtmehr verglichen werden und aus der List gelöscht.
Im zweiten Schritt wird die nun oberste Zahl in eine neue List gespeichert und nach und nach mit allen Zahlen der ersten List(die in die zweite wandern) nach ähnlichem Prinzip verglichen, bis diese zweite List nun sortiert ist und ausgegeben werden kann.
Im Schnitt werden etwa 600-700 Vergleiche benötigt.

Der Code sieht so aus:
Java:
import java.util.ArrayList;
import java.util.Collections;
//diese Klasse erzeugt eine Anzahl Zahlen, speichert sie in eine ArrayList, mischt sie durch und sortiert sie wieder 
//Version 1.0; September/2011
//
public class Sortierer 
{	
static int zaehler = 0;					//Zählervariable		
	public static void main(String[] args) 
	{
		//erzeuge die beiden ArryLists in denen die Zahlen gespeichert werden
		ArrayList<Integer> stapelEins = new ArrayList<Integer>();
		ArrayList<Integer> stapelZwei = new ArrayList<Integer>();
		//erzeuge 52 Zahlen in die Array List stapelEins
		for(int i=0; i<52; i++)
		{
			stapelEins.add(i);
		}
		System.out.println(stapelEins);
		//Mische die Zahlen
		Collections.shuffle(stapelEins);
		System.out.println(stapelEins);
		
		//diese Schleife sortiert die Liste von unten nach oben durch und ermittelt somit die höchste Zahl
		for(int i=51; i>0; i--)
		{
			if (stapelEins.get(i)>stapelEins.get(i-1))
			{
				Collections.swap(stapelEins, i, i-1);				//swap wechselt die Plätz zweier Zahlen
				zaehler++;
			}
			else
			{
				break;
			}
		}
		//die oberste höchste Zahl wird nun vom Stapel entfernt
		stapelEins.remove(0);	
		//die darauf folgende Zahl wird nun auf den zweiten Stapel gelegt
		stapelZwei.add(stapelEins.get(0));
		//diese Schleife fügt eine Zahl nach der anderen dem zweiten Stapel hinzu, während die zweite
		//Schleife diesen neuen Stapel bottom-up durchsortiert und so jede neue Zahl an die höchstmöglich Position bringt
			for(int i=1; i<51; i++)
			{	
				stapelZwei.add(i, stapelEins.get(i));				//neue Zahl hinzufügen

					for(int j = stapelZwei.size(); j>1; j--)
					{
						
						if(stapelZwei.get(j-1)>stapelZwei.get(j-2))	//vergleich solange Karte eins kleiner als die folgende 
						{
							Collections.swap(stapelZwei, j-1, j-2);	//swap wechselt die Plätz zweier Zahlen
							zaehler++;								//Zähler wird erhöht
							System.out.println(stapelZwei);  	// <--- ermöglicht die Nachvollziehbakeit der Sortiervorgänge
						}
						else
						{
							break;
						}	
					}		
	    	}
			//nun wird die höchste Karte wieder hinzugefügt
			stapelZwei.add(0, 51);	
			//und Stapel wie Zähler ausgegeben 
			System.out.println(stapelZwei);
			System.out.println("insgesamt " + zaehler + " Vergleiche");	
	}	
}

Um die Anzahl der Versuch nun weiter zu reduzieren würde es sich anbieten, wenn man nicht nur qualitative sondern auch quantitative Vergleiche anstellen könnte. Will heissen, dass zwei Zahlen, die sich genau um 1 unterscheiden, bei zukünftigen Vergleichen nichtmehr einzeln verglichen werden müssen sondern nur noch eine diese Paars, Trios, Quartetts etc. verglichen werden muss um eine Aussage treffen zu können.
Leider bietet eine ArrayList keine Standardmethode um das zu implementieren und mir fällt trotz vielem Grübeln keine Lösung für das Problem ein.
Hat jemand ne Idee?
 
Zuletzt bearbeitet:

JCODA

Top Contributor
Eine weniger algorithmische sonder objektorientierte Lösung wäre: Du schreibst dir eine Klasse für ein Zahlenpaar:

Java:
public class Zahlenpaar{

private int zahl;
private int anzahl;

public Zahlenpaar(int zahl, int anzahl){
this.zahl = zahl;
this.anzahl=anzahl;
}
//getter und setter
}
 

locolukas

Mitglied
Danke!
Hatte mir auch schon überlegt das über eine Klasse zu Lösen:
Wenn ich dich richtig verstehe:
Ein Objekt speichert sowohl den Wert Zahl(wird sortiert) als auch den Wert Anzahl(Platz in der Reihenfolge)
ArrayList wird nur zum Mischen und Initialisieren der Variablen verwendet und übergibt dann Wert und Platz an die Objekte.
Oder die Objekte werden mit Math.random mit Werten belegt.
Bleibt aber noch das Problem:
Java:
if(objekt1.getZahl - objekt2.getZahl = 1){
   //wie kann hier nun erreicht werden, dass objekt1 beim weiteren sortieren nichtmehr berücksichtigt wird(einfach)
   //aber trotzdem mit objekt2 den Platz in der Reihenfolge verändert(auch möglich)
   //jedoch ohne weiteren objekten in die quere zu kommen, die während des sortierens evt. den
   //Platz hinter objekt2 einnehmen (möglich?)
}

Oder übersehe ich hier was wesentliches?:confused::confused:
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
W ArrayList löscht alle Elemente bis auf eines Java Basics - Anfänger-Themen 2
M Elemente in einer ArrayList einander zuordnen. Java Basics - Anfänger-Themen 18
D Klassen Doppelt so viele Elemente in Arraylist ? Java Basics - Anfänger-Themen 4
gamebreiti Gui menu ArrayList Elemente wiedererkennen Java Basics - Anfänger-Themen 3
V wie kann ich in zweidimensionaller Arraylist auf die einzelnen Elemente zugreifen ? Java Basics - Anfänger-Themen 7
C ArrayList - überschreibt Elemente Java Basics - Anfänger-Themen 7
R Best Practice Elemente aus ArrayList entfernen (performant) Java Basics - Anfänger-Themen 6
H Redundante Elemente aus ArrayList entfernen Java Basics - Anfänger-Themen 3
E Elemente einer (öffentlichen) ArrayList in einer anderen Klasse zu einer ArrayList dazu fügen. Java Basics - Anfänger-Themen 7
T Elemente aus einem ArrayList entfernen Java Basics - Anfänger-Themen 12
S Auf ArrayList Elemente zugreifen Java Basics - Anfänger-Themen 5
N ArrayList wird immer um zwei Elemente erweitert Java Basics - Anfänger-Themen 9
S Bestimmte Elemente einer ArrayList löschen Java Basics - Anfänger-Themen 3
C ArrayList: Elemente addieren Java Basics - Anfänger-Themen 3
J arraylist ausserhalb der main Methode zugänglich machen (Elemente adden und updaten) Java Basics - Anfänger-Themen 4
E Elemente in Arraylist spiegeln? Java Basics - Anfänger-Themen 9
R Anzahl gleicher Elemente in ArrayList Java Basics - Anfänger-Themen 5
G Häufigkeit der Elemente in einer ArrayList zählen Java Basics - Anfänger-Themen 2
G Elemente in einer ArrayList anhand ID löschen Java Basics - Anfänger-Themen 17
K Kombinationen der Elemente einer ArrayList Java Basics - Anfänger-Themen 4
krgewb ArrayList allgemein halten Java Basics - Anfänger-Themen 6
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
M Letztes Element einer ArrayList Java Basics - Anfänger-Themen 12
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
I Sortiert eine HashMap nicht gleich wie eine ArrayList? Java Basics - Anfänger-Themen 1
I ArrayList erstellen innerhalb einer Zeile? Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
F java.util.ArrayList Java Basics - Anfänger-Themen 3
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
M Zugriff auf eine ArrayList in einer anderen Klasse Java Basics - Anfänger-Themen 4
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
N Methode mit einer Arraylist Java Basics - Anfänger-Themen 106
I ArrayList - Methode zum Speichern eines Eintrags in einer Datei Java Basics - Anfänger-Themen 17
H ArrayList Java Basics - Anfänger-Themen 7
D public ArrayList(Collection<? extends E> c); Java Basics - Anfänger-Themen 2
M JTextField in ArrayList speichern Java Basics - Anfänger-Themen 4
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13

Ähnliche Java Themen

Neue Themen


Oben