【问题标题】:Change LinkedHashMap items in reverse order [duplicate]以相反的顺序更改 LinkedHashMap 项目[重复]
【发布时间】:2019-01-09 12:18:52
【问题描述】:

我想以相反的顺序更改我的 LinkedHashMap 中的元素。像这样的:

public static void main(String[] args){
    Map<String, Integer> map = new LinkedHashMap<>();
    map.put("Hello", 2);
    map.put("World", 1);
    reverse(map);
    System.out.println(map);// {Wordl=1, Hello=2}
}

public static void reverse(Map<String, Integer> map){
   // Reverse my map...
}

但我没有找到任何可以帮助我做到这一点的东西。有人可以建议如何解决这个问题吗? 谢谢。

【问题讨论】:

  • @Jabongg 我认为这不是 OP 所需要的,他需要能够产生 {Hello=2, Wordl=1} 我认为...
  • @Jabongg - Q&A 是关于创建逆映射的。这不是那个的副本。
  • 耶!你说的对。这是关于反转整个地图。谢谢斯蒂芬 C @A4L
  • @Jabongg,在这个问题中交换了键和值。我还有一个问题。
  • 耶!我明白了。

标签: java dictionary collections


【解决方案1】:

您可以使用此代码以相反的顺序进行迭代:

   ListIterator<Map.Entry<String, Integer>> iterator = new ArrayList<Map.Entry<String, Integer>>(map.entrySet()).listIterator(map.size());
            while (iterator.hasPrevious()) {
                Map.Entry<String, Integer> entry = iterator.previous();
                System.out.println(entry.getValue());
            }

【讨论】:

  • @StasUmanets 欢迎您,别忘了投票!
  • 从Java 7开始,你可以写new ArrayList&lt;&gt;(map.entrySet())而不是new ArrayList&lt;Map.Entry&lt;String, Integer&gt;&gt;(map.entrySet())
【解决方案2】:

你看过这里吗:

How to traverse Linked Hash Map in reverse?

查看第二个答案,它提供了有关如何遍历的选项。 另请参阅 Guava 库的链接。

【讨论】:

  • 好的,我去看看 Guava 库。
【解决方案3】:

// 你可以使用 Arraylist。这是一个实现。

    public static void main(String[] args) {

    Map<String, String> map = new LinkedHashMap<String, String>();
    map.put("Hello", "2");
    map.put("World", "1");
    // create an arraylist initialized with keys of map
    ArrayList keyList = new ArrayList(map.keySet());
    for (int i = keyList.size() - 1; i >= 0; i--) {
        // get key
        String key = (String) keyList.get(i);
        System.out.println("Key :: " + key);
        // get value corresponding to key
        String value = map.get(key);
        System.out.println("Value :: " + value);
        System.out.println("--------------------------------");
    }
}

【讨论】:

  • 谢谢,我会试试的。
猜你喜欢
  • 2011-11-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多