java中的TreeMap

TreeMap集合

java 复制代码
package dailyTest;

import javax.persistence.criteria.CriteriaBuilder;
import java.util.StringJoiner;
import java.util.TreeMap;
import java.util.function.BiConsumer;

/**
 * @author 
 * @createtime 2023/9/13 10:03
 */
public class A03_TreeMapDemo3 {
    public static void main(String[] args) {
        /**
         * 需求:字符串"aababcabcdabcde"
         * 请统计字符串中每一个字符出现的次数,并按照一下格式输出
         * a(5)b(4)c(3)d(2)e(1)
         * 分析:
         * 统计 ---->计数器思想
         * HashMap
         * TreeMap
         * 键:要统计的内容
         * 值:表示次数
         * 如果题目中没有要求对结果进行排序,默认使用HashMap
         * 如果题目中要求对结果进行排序,使用TreeMap
         */
        //1.定义字符串
        String s = "aababcabcdabcde";
        //2.创建集合
        TreeMap<Character, Integer> tm = new TreeMap<>();
        //2.遍历字符串得到里面的每一个字符串
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);
            //拿着c到集合中判断是否存在
            //存在,表示当前字符又出现了一次
            //不存在,表示当前字符是第一次出现
            if(tm.containsKey(c)){
                //存在
                //先把已经出现的次数拿出来
                int count = tm.get(c);
                //当前字符又出现了一次
                count++;
                tm.put(c,count);
            }else {
                //不存在
                tm.put(c,1);
            }
            System.out.println(c);
            //4.遍历集合,并按照指定的格式进行拼接
            //StringBuilder
            //StringJoiner
            //a(5)b(4)c(3)d(2)e(1)
            StringBuilder sb = new StringBuilder();
            tm.forEach(new BiConsumer<Character, Integer>() {
                @Override
                public void accept(Character key, Integer value) {
                    sb.append(key).append("(").append(value).append(")");
                }
            });
            System.out.println(sb);
//            StringJoiner sj = new StringJoiner("","","");
//            tm.forEach(key,value);
        }
    }
}

总结:

1.TreeMap集合的特点是怎么样的?

  • 不重复、无索引、可排序
  • 底层基于红黑树实现排序,增删改查性能较好

2.TreeMap集合排序的两种方式

  • 实现Comparble接口,指定比较规则
  • 创建集合时传递Comparator结合,指定比较规则
相关推荐
强化学习与机器人控制仿真12 分钟前
openpi 入门教程
开发语言·人工智能·python·深度学习·神经网络·机器人·自动驾驶
明月看潮生1 小时前
青少年编程与数学 02-019 Rust 编程基础 08课题、字面量、运算符和表达式
开发语言·青少年编程·rust·编程与数学
什码情况1 小时前
星际篮球争霸赛/MVP争夺战 - 华为OD机试真题(A卷、Java题解)
java·数据结构·算法·华为od·面试·机试
天天打码1 小时前
Rspack:字节跳动自研 Web 构建工具-基于 Rust打造高性能前端工具链
开发语言·前端·javascript·rust·开源
Petrichorzncu1 小时前
Lua再学习
开发语言·学习·lua
AA-代码批发V哥1 小时前
正则表达式: 从基础到进阶的语法指南
java·开发语言·javascript·python·正则表达式
字节高级特工1 小时前
【C++】”如虎添翼“:模板初阶
java·c语言·前端·javascript·c++·学习·算法
晴天下小雨o2 小时前
排序算法总结
java·算法·排序算法
曼岛_2 小时前
[Java实战]Spring Boot 整合 Redis(十八)
java·spring boot·redis
向哆哆2 小时前
Netty在Java网络编程中的应用:实现高性能的异步通信
java·网络·php