Java学习笔记_Day23(HashMap)

HashMap的特点

  1. HashMap是Map里面的一个实现类
  2. 直接使用Map里面的方法就可以了
  3. 特点是由键决定的:无序,不重复,无索引
  4. HashMap和HashSet底层原理是一样的,都是哈希表结构

LinkedHashMap

  • 由键决定:有序,不重复,无索引
  • 存储和取出的元素顺序一致
  • 原理:底层数据结构依然是哈希表,只是每个键值对元素又额外的多一个双链表的机制记录存储的顺序

TreeMap

  • TreeMap和TreeSet底层原理一样,都是红黑树结构
  • 不重复,无索引,可排序
  • 对键进行排序
  • 默认从小到大排序

代码书写两种排序规则

  • 实现Comparable接口,指定比较规则
复制代码
@Override
public int compareTo(Student o) {
    int i=this.getAge()-o.getAge();
    i=i==0?this.getName().compareTo(o.getName()):i;
    return i;
}
  • 创建集合时传递Comparator比较器对象,指定比较规则
复制代码
TreeMap<Integer, String> tm = new TreeMap<>(new Comparator<Integer>() {

    @Override
    public int compare(Integer o1, Integer o2) {
        return o2-o1;
    }
});

统计字符串字母出现的次数

复制代码
String s="aababccddacbdaac";
TreeMap<Character,Integer> map=new TreeMap<>();
for(int i=0;i<s.length();i++){
    char c=s.charAt(i);
    if(map.containsKey(c)){
        map.put(c,map.get(c)+1);
    }
    else {
        map.put(c,1);
    }
}
System.out.println(map);
相关推荐
村口张大爷2 分钟前
01 — MVC 与 DDD 的思维差异
java·后端
疯狂成瘾者5 分钟前
对比JAR 包部署 vs Docker 部署方式
java·docker·jar
丑八怪大丑6 分钟前
Java范型
java·开发语言
加藤不太惠6 分钟前
Nacos简单实用集群创建
java·开发语言·nacos
空中海8 分钟前
第一篇:入门篇 — 认识 Spring Boot 与基础开发
java·spring boot·后端
求学的小高8 分钟前
数据结构Day10(ASL、二分查找、分块查找)
数据结构·笔记·考研
我能坚持多久8 分钟前
C++的Vector学习:从功能探索到底层实现
开发语言·c++·学习
RainCity9 分钟前
Java Swing 自定义组件库分享(三)
java·笔记
凤凰院凶涛QAQ10 分钟前
《C++转java快速入手系列》类与对象篇
java·开发语言·c++
Devin~Y13 分钟前
大厂Java面试实录:Spring Boot/Cloud + Redis/Kafka + JWT + RAG/Agent(小Y翻车版)
java·spring boot·redis·spring cloud·kafka·spring security·jwt