HashMap Key Reihenfolge umkehren

Status
Nicht offen für weitere Antworten.

lain

Mitglied
Hey,

Ich sitz seit heut mittag an dem Problem habs ewig oft gegooglet und sonstwas getan aber komm auf kein grünen Zweig.

Zum Problem...
Ich will eine gefüllte HashMap die in etwa so aussieht

Code:
HashMap<Integer, String> map = new HashMap<Integer, String>();
map.put(5, "test1");
map.put(11, "vogel");
map.put(20, "hello");
//map wäre so aufgebaut
map= {5=test1, 11=vogel, 20=hello}

//von der Reihenfolge will ich sie aber so hinbiegen...
map = {20=hello, 11=vogel, 5=test1}

denn er sortiert blöderweise immer nach Keys ...
hat jemand ne Idee wie ich die Map so benutzen kann das die keys mit den höchsten einträgen (desc) als erstes eingetragen werden??:confused:
 

Murray

Top Contributor
Das geht nicht; bei einer HashMap gibt es keine definierte Reihenfolge.
javadoc hat gesagt.:
This class makes no guarantees as to the order of the map; in particular, it does not guarantee that the order will remain constant over time.
 

andre111

Bekanntes Mitglied
Der Ansatz ist zwar glaub ich bescheuert, aber ich würde in dem Fall entweder selber so ne Map schreiben, oder du liest halt jedes mal alle Einträge der Map aus kopierst die mithilfe eines selber implementierten Pair in eine Liste und sortierst diese dann nach dem gewünschten Kriterium.

Oder du speicherst die ganzen Daten gleich als Pairs in eine Liste.
 

lain

Mitglied
Der Ansatz ist zwar glaub ich bescheuert, aber ich würde in dem Fall entweder selber so ne Map schreiben, oder du liest halt jedes mal alle Einträge der Map aus kopierst die mithilfe eines selber implementierten Pair in eine Liste und sortierst diese dann nach dem gewünschten Kriterium.

Oder du speicherst die ganzen Daten gleich als Pairs in eine Liste.

Das mit den Pairs in ne Liste wär definitiv ne Möglichkeit ich werds wahrscheinlich so machen...

@ Murray
War auch erst meine Idee aber es ist total kotzig die map umgekehrt zu sortieren .. hast zu zufällig n einfaches snippet oder so als beispiel?
 
Zuletzt bearbeitet:
G

Gelöschtes Mitglied 5909

Gast
nicht die schnellste Lösung was performance angeht aber ansonsten ganz nett:

Code:
package de.test;

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

public class Foo {

    public static void main( String[] args ) {
        Map<Integer, String> map = new HashMap<Integer, String>() {
            {
                put(1, "eins");
                put(2, "zwei");
                put(3, "drei");
            }
        };

        List<Integer> list = new ArrayList<Integer>(map.keySet());
        Collections.sort(list);
        Collections.reverse(list);

        for ( Integer integer : list ) {
            System.out.println("reverse sorted key -> " + integer);
        }

        for ( Integer integer : list ) {
            System.out.println("reverse map " + integer + " -> "
                    + map.get(integer));
        }

    }

}

reverse sorted key -> 3
reverse sorted key -> 2
reverse sorted key -> 1
reverse map 3 -> drei
reverse map 2 -> zwei
reverse map 1 -> eins
 

0x7F800000

Top Contributor
Der TreeMap kannst du doch einen eigenen Comparator übergeben, wo ist dann überhaupt das Problem?
Code:
TreeMap<Integer,String> map=new TreeMap(new Comparator<Integer>(){
    @Override
    public int compare(Integer a, Integer b){
       return b.compareTo(a);
    }
});

map.put(Integer.valueOf(1),"one");
map.put(Integer.valueOf(2),"two");
map.put(Integer.valueOf(3),"three");

//sollte in reihenfolge "three","two","one" gespeichert werden
ist ungetestet und nur schnell hingehackt.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Daniel_L Map/HashMap - Reihenfolge von Einträgen Allgemeine Java-Themen 4
T HashMap#values Reihenfolge Allgemeine Java-Themen 13
T HashMap, sortiert nach Reihenfolge Allgemeine Java-Themen 7
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
T HashMap values Bearbeitung Allgemeine Java-Themen 4
T Hashmap Values Bearbeitung Allgemeine Java-Themen 1
JavaJakob22 Bestimmte HashMap importieren Allgemeine Java-Themen 4
killig HashMap mit if-Anweisung überprüfen Allgemeine Java-Themen 4
killig Textdatei einlesen und in HashMap speichern (duplikate entfernen) Allgemeine Java-Themen 12
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
L HashMap Allgemeine Java-Themen 10
X Collections Gibt es eine Klasse welche die Vorteile von List und HashMap vereint, aber konstante Laufzeit (O(1)) hat in Java? Allgemeine Java-Themen 4
B HashMap Duplikate Allgemeine Java-Themen 4
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
W Array vs. ArrayList vs. HashMap Allgemeine Java-Themen 20
F Tabelle aus CSV, 2 dimensionale HashMap? Allgemeine Java-Themen 4
D Mit Java PHP hashmap lesen Allgemeine Java-Themen 1
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
B HashMap aus Value Key bekommen Allgemeine Java-Themen 2
N HashMap und Methoden richtig einbinden Allgemeine Java-Themen 2
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
X JSONObject auslesen und in HashMap hinterlegen Allgemeine Java-Themen 16
N Werte aus Hashmap auslesen und übertragen Allgemeine Java-Themen 8
JavaWolf165 JsonObject in HashMap umwandeln Allgemeine Java-Themen 16
R ArrayList und HashMap Allgemeine Java-Themen 7
L Assoziatives Datenfeld, schneller wie Hashmap Allgemeine Java-Themen 35
G Methoden HashMap speichert unter falschen Schlüsseln Allgemeine Java-Themen 6
D Verschachtelte HashMap initializieren Allgemeine Java-Themen 1
L Variablen HashMap nimmt value nicht an Allgemeine Java-Themen 3
R Hierarchie mit HashMap darstellen Allgemeine Java-Themen 19
D Datentypen HashCollision in HashMap Allgemeine Java-Themen 3
Z Concurrent Modification Exception - HashMap (kein remove) Allgemeine Java-Themen 4
B Zugriff auf eine HashMap Allgemeine Java-Themen 4
B Userdaten in Hashmap speichern - Servlet Allgemeine Java-Themen 6
T Hashmap mit geordneter/ungeordneter liste als Value Allgemeine Java-Themen 5
I HashMap key wird nicht erkannt trotz überschriebener equals/hashCode Methode Allgemeine Java-Themen 6
M Füllfaktor einer Hashmap Allgemeine Java-Themen 7
A Collections HashMap.containsKey findet keine immutablen Objekte Allgemeine Java-Themen 3
D Datentypen HashMap Allgemeine Java-Themen 5
R Collections Performance einer HashMap Allgemeine Java-Themen 26
C LinkedList und ArrayList in HashMap Allgemeine Java-Themen 4
T Erste Schritte HashMap<String, int> Allgemeine Java-Themen 2
K Hashmap sortieren Allgemeine Java-Themen 6
F HashMap überschreibt Daten von anderen HashMap Allgemeine Java-Themen 5
S HashMap containsKey liefert immer false zurück Allgemeine Java-Themen 15
H Problem beim Sortieren einer HashMap mit TreeSet Allgemeine Java-Themen 4
K HashMap sorting verhindern Allgemeine Java-Themen 10
J Generic von einer ArrayList/HashMap bekommen Allgemeine Java-Themen 7
L HashMap mit Enum Keys Allgemeine Java-Themen 3
J Array als Schlüssel für HashMap Allgemeine Java-Themen 6
S Geschwindigkeit HashMap oder .getParent Allgemeine Java-Themen 5
V Hashmap-Frage Allgemeine Java-Themen 3
M HashMap - Ich bin verwirrt Allgemeine Java-Themen 3
H2SO3- multiple Hashmap Allgemeine Java-Themen 5
K Threading - schreiben auf Hashmap/löschen - ConcurrentModificationException Allgemeine Java-Themen 3
J NullPointerException mit HashMap Allgemeine Java-Themen 2
V Probleme mit eigener Hashmap Allgemeine Java-Themen 10
N HashMap<String,Vector<String>> a = new HashMap<String,Vector<String>>(); Allgemeine Java-Themen 4
I HashMap Problem... Allgemeine Java-Themen 3
C HashMap Allgemeine Java-Themen 12
N wie greife ich auf hashmap in vector zu Allgemeine Java-Themen 9
J Inhalt von HashMap vergleichen Allgemeine Java-Themen 3
Z Serialisierung und Deserialisierung einer HashMap Allgemeine Java-Themen 17
P Wieso HashMap-Zugriff mit Object, statt mit MyObject? Allgemeine Java-Themen 12
K Serialisierung von Hashmap in Vector Allgemeine Java-Themen 3
T Hashmap füllen mit rs sortierung Allgemeine Java-Themen 9
D HashMap sortieren Allgemeine Java-Themen 2
P Große Datenmenge wie speichern (HashMap? TreeMap?) Allgemeine Java-Themen 11
D HashMap Problem Allgemeine Java-Themen 14
G Runnables aus Hashmap starten Allgemeine Java-Themen 4
J java.util.ConcurrentModificationException bei HashMap? Allgemeine Java-Themen 2
G HashMap key ändern Allgemeine Java-Themen 5
L HashMap / Objekte auf Festplatte zur Laufzeit auf HD swappen Allgemeine Java-Themen 7
S Problem mit Hashmap Allgemeine Java-Themen 2
G Datei einlesen und in HashMap verarbeiten Allgemeine Java-Themen 3
E Auslesen aus Hashmap Allgemeine Java-Themen 3
P HashMap mit mehreren gleichen keys Allgemeine Java-Themen 4
alexpetri hashmap bästpractice Allgemeine Java-Themen 4
J HashMap mit Webservice realisierbar? Allgemeine Java-Themen 4
ARadauer hashmap vs hastable Allgemeine Java-Themen 5
M ArrayList sortieren - HashMap mit sort_id vorhanden Allgemeine Java-Themen 2
L Wie kann ich eine HashMap abspeichern? Allgemeine Java-Themen 3
T HashMap (String, Object(String , int)) nach int sortieren Allgemeine Java-Themen 7
M HashMap kapselt zwei Objekte aber wie baut man eine Matrix? Allgemeine Java-Themen 2
E MySQL-Datenbank <-> HashMap/TreeMap Allgemeine Java-Themen 1
P List in Hashmap schreiben Allgemeine Java-Themen 5
M Threads in einer Hashmap Allgemeine Java-Themen 5
P HashMap an 2 Stellen veränderbar Allgemeine Java-Themen 13
P HashMap auflösen Allgemeine Java-Themen 9
MQue HashMap durchlaufen Allgemeine Java-Themen 2
MQue HashMap Allgemeine Java-Themen 2
M HashMap kommt beim Löschen aus dem Tritt Allgemeine Java-Themen 6
MQue HashMap Allgemeine Java-Themen 6
MQue HashMap Allgemeine Java-Themen 9
MQue Sichtbarkeit/HashMap/NullPointerexception Allgemeine Java-Themen 2
B HashMap.containsKey. Allgemeine Java-Themen 10
J byte-Array in Hashmap speichern? Allgemeine Java-Themen 3
S Klasse in HashMap speichern Allgemeine Java-Themen 3
G [quote]the type HashMap is not generic; it cannot be paramet Allgemeine Java-Themen 4
M HashMap sortiert Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben