>  Q&A  >  본문

java - 【算法】HashMap按照value排序

阿里面试的时候面试官提出的一个问题:

给定一个HashMap<String, BuziObj> buziObjMap;,其中 BuziObj 实现了
Comparable 接口。现在需要将 buziObjMap 按照 BuziObj 有序输出。注意,BuziObj
实例有可能相等,要求多次返回的结果一致。可以使用JDK提供的各种API。

当时自己的想法是,将 buziObjMapvalues 放在一个 List 中。然后使用 Collections.sort(valuesList) 对存放 valuesvaluesList 排序。再遍历排序之后的 valuesListbuziObjMap,比对 valuesListbuziObjMap 中的值,相等之后,将当前 buziObjMap 中的 Entry 放在 LinkedHashMap 中,返回 LinkedHashMap 即可。

但是如上解法主要存在两个问题:
1,不满足多次执行返回结果一致这个要求,因为在遍历 valuesListbuziObjMap 时,buziObjMap的输出顺序无法保证每次都是一致的。
2,算法的复杂度过大。

针对这个问题,各位同学有什么更好的解法,麻烦提供一下思路。

黄舟黄舟2716일 전740

모든 응답(3)나는 대답할 것이다

  • 黄舟

    黄舟2017-04-18 10:54:16

    으아아아

    회신하다
    0
  • PHP中文网

    PHP中文网2017-04-18 10:54:16

    왜 값을 목록에 넣어야 하나요? Entry를 직접 넣는 것이 훨씬 간단하지 않을까요?

    회신하다
    0
  • 天蓬老师

    天蓬老师2017-04-18 10:54:16

    지나갑니다~지나갑니다~지나갑니다~지나갑니다~지나갑니다~지나갑니다~지나갑니다~지나갑니다~지나갑니다~

    회신하다
    0
  • 취소회신하다