兰舟千帆 2022-02-14 18:21 采纳率: 76.2%
浏览 45
已结题

一个关于比较器重写的问题,java



package java_practice;

import java.util.Collection;
import java.util.Comparator;
import java.util.Set;
import java.util.TreeMap;

public class TreeMapDemo {
    public static TreeMap<String,Integer> tm;

    public static void main(String[] args) {
        //Comparator comparator;
        tm = new TreeMap(new TreeMapCompare());
        tm.put("lqx",12);
        tm.put("fqy",16);
        tm.put("znk",10);
        tm.put("jgdabc",20);
    }



    public static class TreeMapCompare implements   Comparator<String>{

        @Override
        public int compare(String key1, String key2) {
            Integer v1 = tm.get(key1);
            Integer v2 = tm.get(key2);
            return v1.compareTo(v2 )==0?
                    key1.compareTo(key2)    //如果value相等则比较key
                    :
                    v1.compareTo(v2 ); //如果value不等则按照value比较


        }
    }

}

img

  • 写回答

3条回答 默认 最新

  • 金山老师 2022-02-14 20:47
    关注

    兄弟,我在你上一个问题给你回复了

    package org.jshand.itextpdf;
    
    import java.util.Comparator;
    import java.util.HashMap;
    import java.util.TreeMap;
    
    /**
     * 项目:commons
     * 创建时间:  2022-02-14   16:12
     * 作者 :金山
     * 描述 :
     */
    public class TreeMapCompareDemo {
    
        /**
         * 全局map,便于比较器中使用
         */
    
    
        public static void main(String[] args) {
            Comparator comparator;
            HashMap<String,Integer> baseMap = new HashMap();
            baseMap.put("lqx",12);
            baseMap.put("fqy",16);
            baseMap.put("znk",10);
            baseMap.put("aa",15);
            baseMap.put("bb",15);
            baseMap.put("cc",20);
            baseMap.put("dd",20);
            baseMap.put("jgdabc",20);
    
            TreeMap tm = new TreeMap(new TreeMapCompare(baseMap));
            tm.putAll(baseMap);
    
            System.out.println(tm);
        }
    
    
    
        static class TreeMapCompare implements   Comparator<String>{
            private HashMap<String,Integer> baseMap = null;
    
            public TreeMapCompare(HashMap baseMap) {
                this.baseMap = baseMap;
            }
    
            @Override
            public int compare(String key1, String key2) {
                Integer v1 = baseMap.get(key1);
                Integer v2 = baseMap.get(key2);
                return v1.compareTo(v2 )==0?
                        key1.compareTo(key2)    //如果value相等则比较key
                              :
                        v1.compareTo(v2 ); //如果value不等则按照value比较
    
    
            }
        }
    
    }
    
    
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月22日
  • 已采纳回答 2月14日
  • 创建了问题 2月14日

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同