Mergesort mit ArrayList

imboar

Neues Mitglied
Guten Tag liebe Freunde der Javaprogrammierung.

Ich muss aktuell den Mergesortalgorithmus in Java implementieren unter zuhilfenahme von Arraylisten. Soweit ist der Algorithmus nicht schwer, doch sitze sich seit einigen Stunden an dem Problem, das nach dem ausführen von mergeSortInt() auf das übergebene Array, dies mit der Größe 0 und ohne Inhalt wieder zurückgegeben wird. Ich finde partout nicht den Grund dafür.

Edit: Zum testen erzeuge Ich eine Arrayliste mit 50 Zufallszahlen(int) die Ich der Methode übergebe. Diese kommen im Programm auch korrekt an.

Java:
import java.math.BigInteger;
import java.util.ArrayList;


public class Mergesort {
  public static void sortInt(ArrayList<Integer> array) {
    
    //Hier ist die Arraygröße noch korrekt.

    array = mergeSortInt(array);

    //Hier ist die Arraygröße = 0, demzufolge auch ohne Inhalt
  }  
  
  
  public static void sortBig(ArrayList<BigInteger> array) {
    
    
    
  }
  
  public static ArrayList<Integer> mergeSortInt (ArrayList<Integer> array) {
    
    int p = (array.size() / 2);
    int x = 0;
    ArrayList<Integer> links = new ArrayList<Integer>(p);    
    ArrayList<Integer> rechts = new ArrayList<Integer>(p);
    
    if (array.size() > 1) {
      
      for (int i = 0; i < array.size() / 2; i++) {
        
        links.add(i, array.get(i));                                    //Erzeugt linke Teilliste
        
      } // Ende for-Schleife zum erzeugen der linken Liste
      
      for (int i = array.size(); i < (array.size() - 1); i++) {
        
        rechts.add(x, array.get(i));                                  //Erzeugt rechte Teilliste
        x++;
      } // Ende for-Schleife zum erzeugen der rechten Liste 
      
      links = mergeSortInt(links);
      rechts = mergeSortInt(rechts);                                  //Teillisten via MErgesort sortieren
      array = mergeInt(links,rechts);                                 //danach Teillisten zusammenfügen
      return array;
      
    } // Ende if
    else{
      
      return array;
      
    }
    
  }
  
  public static ArrayList mergeInt (ArrayList<Integer> links, ArrayList<Integer> rechts){
    
    int gesamt = links.size() + rechts.size();         
    ArrayList<Integer> sortiert = new ArrayList<Integer>(gesamt);
    int left = 0;
    int right = 0;   
      
      for (int i = 0; i < gesamt - 1; i++) { 
        
        if (links.get(left) >= rechts.get(right)) {
          
          sortiert.add(i, rechts.get(right));                //Falls aktuelles Listenelement rechts > links, füge rechtes Element in neue Liste ein
          right++;
          
        }
        else{
          
          sortiert.add(i, links.get(left));                 //ansonsten das Linke
          left++;
          
        } // Ende else
        
      } //Ende for 
      
    return sortiert;
  }
  
}
 
Zuletzt bearbeitet:

Flown

Administrator
Mitarbeiter
Also wir haben das auch mal an der Uni machen müssen. Die Vorredner haben schon deinen Fehler aufgezeigt und ein zweiter ist:

[JAVA=64]
for (int i = 0; i < gesamt - 1; i++) { ... }
[/code]

Das -1 muss weg weil du es gesamt befüllen musst!

Also damit eine saubere Lösung auch mal hier kursiert, hier mein Code:

Java:
package sort;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class Mergesort {
	
	public static <T extends Comparable<T>> void sort(List<T> list) throws IllegalArgumentException {
		if(list == null) throw new IllegalArgumentException("Array must not be null!");
		Collections.copy(list, mergeSort(list));
	}

	private static <T extends Comparable<T>> List<T> mergeSort(List<T> list) {

		if (list.size() <= 1) return list;
		
		int p = (list.size() / 2);
		
		List<T> left = new ArrayList<T>(p);
		List<T> right = new ArrayList<T>(p);

		left.addAll(list.subList(0, p));
		right.addAll(list.subList(p, list.size()));
		
		return merge(mergeSort(left), mergeSort(right));
	}

	private static <T extends Comparable<T>> List<T> merge(List<T> left, List<T> right) {
		int total = left.size() + right.size();
		List<T> sorted = new ArrayList<T>(total);
		int leftIndex = 0;
		int rightIndex = 0;

		for (int i = 0; i < total; i++) {
			if(rightIndex < right.size() && leftIndex < left.size()) {
				if (left.get(leftIndex).compareTo(right.get(rightIndex)) >= 0) {
					sorted.add(right.get(rightIndex++));
				} else {
					sorted.add(left.get(leftIndex++));
				}
			}
			else if(rightIndex < right.size()) {
				sorted.add(right.get(rightIndex++));
			}
			else {
				sorted.add(left.get(leftIndex++));
			}
		}
		return sorted;
	}
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Mergesort (aber anders) Java Basics - Anfänger-Themen 2
KogoroMori21 MergeSort Algorithmus Java Basics - Anfänger-Themen 2
O Rekursion Mergesort Java Basics - Anfänger-Themen 18
E Methoden 2 Arrays sortieren (MergeSort) Java Basics - Anfänger-Themen 3
H Mergesort aufwand berechen Java Basics - Anfänger-Themen 5
I MergeSort iterativ mit Stacks Java Basics - Anfänger-Themen 13
L Methoden Mergesort methode Java Basics - Anfänger-Themen 4
K MergeSort Stackoverflow Java Basics - Anfänger-Themen 5
K Mergesort Fehler in der Implementierung Java Basics - Anfänger-Themen 2
T MergeSort rekursiv programmieren Java Basics - Anfänger-Themen 8
A Rekursion (anhand von Mergesort) nachvollziehen Java Basics - Anfänger-Themen 4
M Erklärung Code Mergesort Bitte Java Basics - Anfänger-Themen 3
A Probleme mit MergeSort Generische Liste Java Basics - Anfänger-Themen 0
M Mergesort Aufgabe große Probleme Java Basics - Anfänger-Themen 9
P Mergesort Probleme Java Basics - Anfänger-Themen 4
C Mergesort Java Basics - Anfänger-Themen 4
H MergeSort (für Anfänger ) Java Basics - Anfänger-Themen 9
N MergeSort Java Basics - Anfänger-Themen 8
M MergeSort - Zahlen verschwinden Java Basics - Anfänger-Themen 2
P MergeSort mit Liste Java Basics - Anfänger-Themen 4
M MergeSort rekursiv Java Basics - Anfänger-Themen 2
B Methoden Natural Mergesort Java Basics - Anfänger-Themen 2
P Mergesort || 2 SetLists mischen Java Basics - Anfänger-Themen 2
P Mergesort (zyklische Liste) Java Basics - Anfänger-Themen 2
X eigener Mergesort auf generischen Typen mit Comparator Java Basics - Anfänger-Themen 6
N MergeSort mit Liste Java Basics - Anfänger-Themen 8
P Probleme bei codierung von MergeSort Java Basics - Anfänger-Themen 4
M MergeSort - Threads in Anwendung bremsen alles! Java Basics - Anfänger-Themen 4
Houly Mergesort Java Basics - Anfänger-Themen 4
M Mergesort Java Basics - Anfänger-Themen 11
C MergeSort Problem Java Basics - Anfänger-Themen 5
F MergeSort iterativ mit Hilfe von Stack Java Basics - Anfänger-Themen 5
B mergesort/rekursion Java Basics - Anfänger-Themen 9
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
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
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
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
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

Ähnliche Java Themen


Oben