arraylist Index des größten, zweit-,dritt-,...-größten Elemtens ausgeben

Status
Nicht offen für weitere Antworten.

Jagito

Mitglied
Hi,
stehe vor folgendem Problem, für das ich noch keine Lösung (auch nicht im Internet) gefunden habe. Wahrscheinlich fehlen mir die richtigen Schlagworte.

Sei al eine arraylist, welche bspw. 7 Integer enhält, wobei keine Reihenfolge besteht, z.B. könnte die arraylist 4,56,23,1,45,2,3 sein.

Nun versuche ich eine Methode zu generieren, welche mir die Einträge der arraylist nach der Größe sortiert, mir aber nur die Indizes wiedergibt (so dass die arraylist unverändert bleibt) und ich später mit Hilfe der Indizes spezifisch auf einen Eintrag zugreifen kann.

d.h. wenn ich obiges Bsp fortsetze, wäre die Ausgabe (bei Sortierung von Maximum nach Minimum): 1,4,2,0,6,5,3 (die erste Eins, da die größte Zahl-56-an 2.ter Stelle steht)

Wie könnte ich dies implementieren?
 
B

bygones

Gast
liste kopieren in neue Liste, die dann sortieren, drüber iterieren und die jeweiligen objekte in der originalliste suchen (ueber get), das liefter dir die indizes und die kannste wieder in ne liste packen
 

ARadauer

Top Contributor
Eine Klasse erstellen. Diese hat den Wert und den Index den der Wert im Array hat.
Über das Array iterierieren, für jeden Wert ein Objekt der klasse erstellen, dieses Objekt in eine Liste einfügen.
Die Klasse soll nun Compareable implementieren, dass anhand des Wertes sortiert. Nun die Liste sortieren und fertig...
 

ARadauer

Top Contributor
ok was bygones sagt ist auch ganz nett ;-)

Java:
	public static void main(String[] args) {
		int[] values = {4,56,23,1,45,2,3} ;
		
		ArrayList<IndexValue> indexValues = new ArrayList<IndexValue>();
		for(int i = 0; i < values.length; i++)
			indexValues.add(new IndexValue(i, values[i]));
		
		Collections.sort(indexValues);
		
		for(IndexValue iv : indexValues){
			System.out.println(iv);
		}
	}

Java:
public class IndexValue  implements Comparable<IndexValue>{	

	
	private int value;
	private int index;	
	
	public IndexValue(int index, int value) {
		super();
		this.index = index;
		this.value = value;
	}
	
	public int getValue() {
		return value;
	}
	public void setValue(int value) {
		this.value = value;
	}
	public int getIndex() {
		return index;
	}
	public void setIndex(int index) {
		this.index = index;
	}

	@Override
	public int compareTo(IndexValue o) {
		if(getValue()>o.getValue()){
			return 1;
		}else if(getValue()<o.getValue()){
			return -1;
		}
		return 0;
	}
	
	public String toString(){
		return index+" - "+value;
	}
	

}
 

Landei

Top Contributor
Findet ihr das nicht eventuell ein klein wenig übertrieben?

Was haltet ihr davon:
Java:
    private static int[] indexBubbleSort(int[] data) {
        int[] indices = new int[data.length];
        for(int i = 0; i < data.length; i++) {
            indices[i] = i;
        }
        for(int i = data.length-1; i > 0; i--) {
            for(int j = 0; j < i; j++) {
               if(data[indices[j]] < data[indices[j+1]]) {
                   int temp = indices[j];
                   indices[j] = indices[j+1];
                   indices[j+1] = temp;
               }
            }
        }
        return indices;
    }
 

Marco13

Top Contributor
Kommt drauf an, was man erreichen oder vermittlen will. Wenn ich z.B. ein Inf I.. oder II oder III-Tutor wäre, würde ich dem betreffenden Studenten Lösungen, bei denen die Laufzeit für das Finden der k größten von n Elemente im worst case n*k ist genauso um die Ohren hauen, wie eine, bei der das ganze schon bei k=1 im worst case n*n benötigt.... (Aber genaugenommen müßte man überprüfen, ob k<log(n) ist, um die optimale Lösung zu finden...)
 

Landei

Top Contributor
Kommt drauf an, was man erreichen oder vermittlen will. Wenn ich z.B. ein Inf I.. oder II oder III-Tutor wäre, würde ich dem betreffenden Studenten Lösungen, bei denen die Laufzeit für das Finden der k größten von n Elemente im worst case n*k ist genauso um die Ohren hauen, wie eine, bei der das ganze schon bei k=1 im worst case n*n benötigt.... (Aber genaugenommen müßte man überprüfen, ob k<log(n) ist, um die optimale Lösung zu finden...)

Wenn Bubblesort über Indizes zu implentieren geht (und da war ich mir gar nicht so sicher), wird es so ähnlich auch mit anderen Sortierverfahren funktionieren. Ich denke jedenfalls, dass die oben vorgestellten Lösungen ziemlich umständlich sind.
 

Marco13

Top Contributor
Ja, dagegen sag' ich ja auch gar nichts - aber BubbleSort hat eben im Worst case O(n^2). Das hier ist auch nicht viel komplizierter...
Java:
// Marco13 for [url]http://www.java-forum.org/java-basics-anfaenger-themen/90643-arraylist-index-groessten-zweit-dritt-groessten-elemtens-ausgeben.html[/url]
import java.util.*;

class ConnectedSortTest
{
    public static void main(String[] args)
    {
        final int array[] = {4,56,23,1,45,2,3};

        List<Integer> indices = new ArrayList<Integer>();
        for (int i=0; i<array.length; i++)
        {
            indices.add(i);
        }
        Comparator<Integer> comparator = new Comparator<Integer>()
        {
            public int compare(Integer i0, Integer i1)
            {
                return array[i1]-array[i0];
            }
        };

        Collections.sort(indices, comparator);
        System.out.println(indices);
    }
}
(IMHO sogar noch einfacher....) ...und liefert die komplette Indexliste in O(nlogn) - dann geht es nur noch um die Frage, ob man mehr oder weniger als logn indizes haben will...
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
A ArrayList - size() nur nach bestimmtem index anzeigen lassen Java Basics - Anfänger-Themen 13
K Element in ArrayList löschen ohne Index zu verschieben Java Basics - Anfänger-Themen 2
R ArrayList(int index, Object) funktioniert nicht korrekt? Java Basics - Anfänger-Themen 7
C Datentypen ArrayList.remove(index) hinterlässt leeres Feld Java Basics - Anfänger-Themen 5
E Höherer Index als Size in ArrayList 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
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
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
K Zahlenfolge ArrayList Java Basics - Anfänger-Themen 3
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
I Klassen Eine ArrayList<Long>, die sich automatisch sortiert Java Basics - Anfänger-Themen 20
F Array in ArrayList ablegen Java Basics - Anfänger-Themen 3
V ArrayList Java Basics - Anfänger-Themen 1
Z Runden Arraylist Java Basics - Anfänger-Themen 9
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
F Arraylist als Pfadausgabe Java Basics - Anfänger-Themen 10
L Daten aus ArrayList in Datenbank durchsuchen Java Basics - Anfänger-Themen 5
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
M Problem mit ArrayList Java Basics - Anfänger-Themen 32
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
O Hashmap, ArrayList, LinkedList Java Basics - Anfänger-Themen 7
X Problem mit Arraylist in Arraylist Java Basics - Anfänger-Themen 2
O HashMap - ArrayList Java Basics - Anfänger-Themen 29

Ähnliche Java Themen

Neue Themen


Oben