兰舟千帆 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 html5 qrcode 扫描器
  • ¥15 爬取网页信息并保存需要完整代码
  • ¥15 一分十不等功分器阻设计问题,请问这个56Ω怎么得到的
  • ¥15 (标签-matlab)
  • ¥100 求看看这个数学建模,有偿
  • ¥15 深度学习目标检测现在框架加注意力的创新可以投几区?
  • ¥15 PdfiumViewer pdf转图片
  • ¥15 利用Java连接API接口总是出问题
  • ¥15 请教一个关于镜头标定,棋盘格格子大小的问题(畸变测试)
  • ¥15 安装GroudingDINO RuntimeError: Error compiling objects for extension