Maison > Java > javaDidacticiel > Comment effectuer un mappage ordonné à l'aide de la fonction TreeMap en Java

Comment effectuer un mappage ordonné à l'aide de la fonction TreeMap en Java

WBOY
Libérer: 2023-06-26 17:46:06
original
1286 Les gens l'ont consulté

Avec le développement continu de la société moderne, le développement de programmes informatiques est devenu un élément indispensable du domaine de la science et de la technologie. Dans le processus de développement d'un programme, la sélection et l'utilisation des structures de données constituent également un aspect très important. L'une des structures de données couramment utilisées est une carte, qui associe une clé à une valeur. Dans le langage de programmation Java, une série de structures de données cartographiques sont fournies, dont la plus couramment utilisée est la fonction TreeMap. Cet article explique comment utiliser la fonction TreeMap pour le mappage ordonné et démontre son utilisation avec un exemple de code.

1. Qu'est-ce que la fonction TreeMap

Tout d'abord, nous devons comprendre ce qu'est la fonction TreeMap. TreeMap est une structure de données cartographiques basée sur un arbre rouge-noir dans le langage de programmation Java. Il peut trier les paires clé-valeur selon l'ordre naturel des clés ou selon le comparateur fourni. Il s’agit donc d’une structure de données de mappage ordonnée qui peut faciliter les opérations de tri.

2. Utilisation de base de la fonction TreeMap

1. Créer un objet TreeMap

Lorsque vous utilisez la fonction TreeMap, vous devez d'abord créer un objet TreeMap. L'objet TreeMap a deux constructeurs, l'un est un constructeur sans paramètre, qui crée un objet TreeMap vide ; l'autre consiste à créer un objet TreeMap spécifiant un comparateur en fournissant à un constructeur un paramètre Comparator. Par exemple :

// 创建一个空的TreeMap对象
TreeMap<String, Integer> treeMap = new TreeMap<>();

// 创建一个指定比较器的TreeMap对象
TreeMap<String, Integer> treeMap = new TreeMap<>(new MyComparator());
Copier après la connexion

Parmi eux, le type String dans le code ci-dessus est le type de données de la clé, et le type Integer est le type de données de la valeur. MyComparator est une classe de comparaison personnalisée utilisée pour spécifier comment les clés sont triées. Si aucun comparateur n’est fourni, l’ordre naturel des clés est utilisé. String类型是键的数据类型,而Integer类型是值的数据类型。MyComparator是一个自定义的比较器类,用于指定键的排序方式。如果不提供比较器,则使用键的自然排序方式。

2.添加键值对

使用put()方法向TreeMap中添加键值对。例如:

treeMap.put("apple", 3);
treeMap.put("banana", 1);
treeMap.put("orange", 2);
Copier après la connexion

上述代码将添加三个键值对,键分别为"apple"、"banana"和"orange",对应的值为3、1和2。这里需要注意的是,如果添加的键已经存在,会将原有的键值对替换成新的键值对。

3.获取键值对

使用get()方法获取指定键的值。例如:

int value = treeMap.get("apple");
Copier après la connexion

上述代码将获取键为"apple"的值3。

4.删除键值对

使用remove()方法删除指定键的键值对。例如:

treeMap.remove("banana");
Copier après la connexion

上述代码将删除键为"banana"的键值对。

5.遍历TreeMap

使用entrySet()方法获取TreeMap中键值对的集合,然后使用for

2. Ajouter des paires clé-valeur

Utilisez la méthode put() pour ajouter des paires clé-valeur au TreeMap. Par exemple :

for (Map.Entry<String, Integer> entry : treeMap.entrySet()) {
    String key = entry.getKey();
    int value = entry.getValue();
    System.out.println(key + ": " + value);
}
Copier après la connexion

Le code ci-dessus ajoutera trois paires clé-valeur, les clés sont "pomme", "banane" et "orange", et les valeurs correspondantes sont 3, 1 et 2. Il convient de noter ici que si la clé ajoutée existe déjà, la paire clé-valeur d'origine sera remplacée par la nouvelle paire clé-valeur.

3. Obtenez la paire clé-valeur

Utilisez la méthode get() pour obtenir la valeur de la clé spécifiée. Par exemple :

import java.util.Comparator;
import java.util.Map;
import java.util.TreeMap;

public class TreeMapDemo {

    public static void main(String[] args) {

        // 创建一个指定比较器的TreeMap对象
        TreeMap treeMap = new TreeMap<>(new MyComparator());

        // 向TreeMap中添加键值对
        treeMap.put("apple", 3);
        treeMap.put("banana", 1);
        treeMap.put("orange", 2);

        // 获取指定键的值
        int value = treeMap.get("apple");
        System.out.println("apple: " + value);

        // 删除指定键的键值对
        treeMap.remove("banana");

        // 遍历TreeMap
        for (Map.Entry entry : treeMap.entrySet()) {
            String key = entry.getKey();
            value = entry.getValue();
            System.out.println(key + ": " + value);
        }
    }

    // 自定义比较器类
    static class MyComparator implements Comparator {
        @Override
        public int compare(String o1, String o2) {
            // 根据键的长度进行降序排序
            return Integer.compare(o2.length(), o1.length());
        }
    }
}
Copier après la connexion
Le code ci-dessus obtiendra la valeur 3 avec la clé "apple". 🎜🎜4. Supprimer les paires clé-valeur🎜🎜Utilisez la méthode remove() pour supprimer la paire clé-valeur de la clé spécifiée. Par exemple : 🎜rrreee🎜Le code ci-dessus supprimera la paire clé-valeur avec la clé "banane". 🎜🎜5. Parcourez le TreeMap🎜🎜Utilisez la méthode entrySet() pour obtenir la collection de paires clé-valeur dans le TreeMap, puis utilisez la boucle for pour parcourir la collection. Par exemple : 🎜rrreee🎜Le code ci-dessus parcourra chaque paire clé-valeur dans le TreeMap et imprimera respectivement la clé et la valeur. 🎜🎜3. Exemple de code🎜🎜Ce qui suit est un exemple de code complet qui montre comment utiliser la fonction TreeMap pour un mappage ordonné : 🎜rrreee🎜4 Résumé🎜🎜Cet article présente la fonction TreeMap dans le langage de programmation Java, y compris ses bases. utilisation et exemple de code. En étudiant cet article, les lecteurs devraient être capables de maîtriser l'utilisation de la fonction TreeMap pour le mappage ordonné et d'écrire des classes de comparateur personnalisées si nécessaire pour implémenter la méthode de tri des clés spécifiées. Bien entendu, dans le développement réel, il est également nécessaire de sélectionner des structures de données et des algorithmes appropriés en fonction de scénarios commerciaux et d'exigences de données spécifiques pour améliorer l'efficacité du fonctionnement du programme et les capacités de traitement des données. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal