SortedMap、NavigableMap与TreeMap的介绍与应用实例

简介: 这个例子演示了如何使用 `TreeMap`来存储产品和它们的价格,以及如何利用 `TreeMap`的导航功能来查找特定条件下的产品。通过这种方式,`SortedMap`、`NavigableMap`和 `TreeMap`提供了一种非常灵活和强大的方式来处理有序数据。

在Java集合框架中,SortedMapNavigableMapTreeMap是处理有序映射关系的关键接口和实现类。它们为我们在数据结构中的键值对排序和导航提供了丰富的功能。让我们逐一深入了解它们的特性、区别以及如何在实际应用中使用它们。

SortedMap简介

SortedMap是一个接口,扩展了 Map接口,用于保持键的有序性。它确保映射中的键按照升序排列,或者根据构造映射时提供的 Comparator进行排序。这种有序性使得一些操作,如返回第一个(firstKey())或最后一个(lastKey())键,变得简单直接。

NavigableMap简介

NavigableMap接口进一步扩展了 SortedMap接口,添加了导航方法以返回给定搜索目标的最接近匹配项。例如,higherKey(), lowerKey(), ceilingKey(), 和 floorKey()等方法使得查找那些不完全匹配的键变得可能。这些功能在需要精确控制元素排序或者在有序集合中高效搜索时非常有用。

TreeMap简介

TreeMapNavigableMap接口的一个具体实现,它通过红黑树实现。它保证了元素的有序状态并且提供了 NavigableMap接口中定义的所有导航方法。TreeMap是一个非常强大的类,它结合了键的自然排序或者根据 Comparator的排序,以及快速查找、插入和删除操作的能力。

应用实例

假设我们有一个需求,需要存储和排序一些产品的价格,然后根据价格快速找到产品。我们可以使用 TreeMap来实现这个需求。

import java.util.TreeMap;

public class ProductPriceExample {
    public static void main(String[] args) {
        TreeMap<Double, String> priceToProductMap = new TreeMap<>();

        // 添加产品及其价格
        priceToProductMap.put(19.99, "T-Shirt");
        priceToProductMap.put(99.99, "Jeans");
        priceToProductMap.put(299.99, "Smartphone");
        priceToProductMap.put(59.99, "Belt");

        // 显示所有产品及价格
        System.out.println("Products and prices: " + priceToProductMap);

        // 查找比给定价格稍高的第一个产品
        Double higherPrice = priceToProductMap.higherKey(50.00);
        if (higherPrice != null) {
            System.out.println("First product with a price higher than 50: " + priceToProductMap.get(higherPrice));
        }

        // 查找价格最低的产品
        Double lowestPrice = priceToProductMap.firstKey();
        System.out.println("Product with the lowest price: " + priceToProductMap.get(lowestPrice));

        // 查找价格最高的产品
        Double highestPrice = priceToProductMap.lastKey();
        System.out.println("Product with the highest price: " + priceToProductMap.get(highestPrice));
    }
}
​

这个例子演示了如何使用 TreeMap来存储产品和它们的价格,以及如何利用 TreeMap的导航功能来查找特定条件下的产品。通过这种方式,SortedMapNavigableMapTreeMap提供了一种非常灵活和强大的方式来处理有序数据。

目录
相关文章
|
6月前
有关HashMap的computeIfAbsent优雅使用方式
有关HashMap的computeIfAbsent优雅使用方式
64 1
|
Java
java集合框架Set子接口之HashSet源码剖析
HashSet类实现了由哈希表(实际上是HashMap实例)支持的Set接口 , 底层采用HashMap来保存的数据 , 存在HashSet中的元素是无序且不重复的并且HashSet是线程不安全的 , 这种不重复其实是由HashMap实现的 , 所以HashSet的实现也是相对比较简单的 , 对于它的操作其实都是调用HashMap的方法来实现的
66 2
|
2月前
|
存储 Java 容器
HashMap 的基本操作【集合容器知识回顾 ⑤】
本文介绍了HashMap的基本操作,包括创建对象、添加、获取、删除和替换元素、获取所有key的集合、遍历HashMap,以及如何存储自定义类型键值对,并强调了当使用自定义对象作为键时需要重写equals和hashCode方法以确保正确的行为。
HashMap 的基本操作【集合容器知识回顾 ⑤】
|
28天前
|
存储 Java
HashMap 与 TreeMap 的差异
【10月更文挑战第14天】总的来说,HashMap 和 TreeMap 各有其特点和适用范围,我们需要根据具体的需求来选择使用哪种数据结构。在实际应用中,还需要考虑性能、内存使用等因素,以确保选择最适合的集合类型。
|
5月前
|
消息中间件 存储 缓存
面试题--HashMap和TreeMap的区别和应用场景有啥区别?
然后底层调用key的hashCode()方法得出hash值; 过哈希表哈希算法,将hash值转换成数组的下标(注1),下标位置上如果没有任何元素,就把Node添加到这个位置上。如果说下标对应的位置上有值。此时,就会拿着key和链表上每个节点的key进行equal。如果所有的equals方法返回都是false,那么这个新的节点将被添加到链表的末尾。如其中有一个equals返回了true,那么这个节点的value将会被覆盖,如果最终长度大于8就会转成红黑树,红黑树插入;
42 3
|
5月前
|
存储 Java 索引
JavaSE——集合框架二(3/6)-Map系列集合:概述、常用方法(认识Map集合,在什么情形下使用,Map集合体系,Map集合体系的特点)
JavaSE——集合框架二(3/6)-Map系列集合:概述、常用方法(认识Map集合,在什么情形下使用,Map集合体系,Map集合体系的特点)
60 1
|
6月前
|
存储 算法 Java
盘点Java集合(容器)概览,Collection和Map在开发中谁用的最多?
盘点Java集合(容器)概览,Collection和Map在开发中谁用的最多?
63 0
|
存储 Java 索引
单独聊聊HashMap
单独聊聊HashMap
27 0
|
存储 Java 索引
java集合框架List子接口之LinkedList源码剖析
LinkendList从物理结构来说是一种线性结构 , 而从逻辑结构来说是一种链式存储结构 , 虽然是线性结构 , 但是并不会按照线性的顺序存储 , 而是分散存储在内存中 , 通过指针来建立节点与节点之间的联系, 同时实现了Deque这也说明它是一个双向链表 , 在源码中 , 没有看到它对线程安全问题的处理 , 所以它同时还是一个线程不安全的链表 , 也没有看到不允许插入null元素 , 重复元素的处理 , 所以它又是一个允许重复元素以及null元素的链表
56 0
|
存储 Java 程序员
Java集合List介绍和去重方案
Java集合List介绍和去重方案
101 0