recherche
MaisonJavajavaDidacticielExemple de cordes alphanumériques de tri java

Java Tri des chaînes alphanumériques Exemple

Cet exemple démontre le tri d'une liste de chaînes alphanumériques en Java à l'aide d'un comparateur personnalisé. Nous utiliserons une List de chaînes et la méthode Collections.sort(), qui nous permet de spécifier une logique de tri personnalisée.

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class AlphanumericSort {

    public static void main(String[] args) {
        List<String> strings = new ArrayList<>();
        strings.add("apple1");
        strings.add("apple10");
        strings.add("apple2");
        strings.add("banana1");
        strings.add("banana20");
        strings.add("banana10");
        strings.add("apple");


        // Sort using a custom comparator
        Collections.sort(strings, new AlphanumericComparator());

        System.out.println("Sorted strings:");
        for (String str : strings) {
            System.out.println(str);
        }
    }

    static class AlphanumericComparator implements Comparator<String> {
        @Override
        public int compare(String s1, String s2) {
            int i = 0;
            while (i < s1.length() && i < s2.length()) {
                char c1 = s1.charAt(i);
                char c2 = s2.charAt(i);

                if (Character.isDigit(c1) && Character.isDigit(c2)) {
                    int num1 = 0;
                    int num2 = 0;
                    while (i < s1.length() && Character.isDigit(s1.charAt(i))) {
                        num1 = num1 * 10 + (s1.charAt(i) - '0');
                        i++;
                    }
                    while (i < s2.length() && Character.isDigit(s2.charAt(i))) {
                        num2 = num2 * 10 + (s2.charAt(i) - '0');
                        i++;
                    }
                    return Integer.compare(num1, num2);
                } else if (Character.isDigit(c1)) {
                    return 1; // Digits come after letters
                } else if (Character.isDigit(c2)) {
                    return -1; // Digits come after letters
                } else if (c1 != c2) {
                    return c1 - c2; // Compare characters
                } else {
                    i++;
                }
            }
            return s1.length() - s2.length(); // Compare lengths if prefixes are equal

        }
    }
}

Comment puis-je trier efficacement une liste des chaînes alphanumériques en Java?

Tri efficacement des chaînes alphanumériques en Java? La méthode intégrée Collections.sort() utilise un tri de fusion hautement optimisé, qui fournit une complexité temporelle O (n log n) dans les cas moyens et pires. Cependant, l'efficacité dépend fortement de la Comparator que vous fournissez.

Une comparaison de chaînes naïve ne triera pas correctement les chaînes alphanumériques car elle traite les nombres lexicographiquement ("10" avant "2"). Par conséquent, vous devez implémenter une coutume Comparator qui gère correctement la nature alphanumérique des chaînes. L'exemple ci-dessus démontre un tel comparateur. Ce comparateur analyse les cordes, séparant les parties alphabétiques et numériques, et les compare en conséquence. Cette approche évite les conversions de chaînes inutiles ou les bibliothèques externes, conduisant à un tri efficace.

Quelles sont les pièges courants à éviter lors du tri des chaînes alphanumériques en Java?

Plusieurs pièges courants peuvent conduire à un tri incorrect ou inefficace des chaînes alphanumériques:

>
  • Ordonnance lexicographique: La comparaison standard des chaînes traite les nombres lexicographiques. Cela signifie que "10" est considéré comme inférieur à "2", ce qui est incorrect pour le tri alphanumérique. Utilisez toujours un Comparator personnalisé pour gérer les portions numériques en tant que nombres, pas des chaînes.
  • Manipulation incorrecte des pièces alphabétiques et numériques mixtes: a Comparator doit gérer correctement les chaînes avec des combinaisons variées de pièces alphabétiques et numériques. Il doit d'abord comparer les parties alphabétiques, puis les parties numériques, garantissant une commande correcte.
  • Ignorer les zéros principaux: Les pièces numériques doivent être traitées comme des entiers, pas des chaînes. Les zéros principaux ne doivent pas affecter l'ordre de tri.
  • Logique de comparaison inefficace: Un Comparator mal conçu peut conduire à un tri inefficace. Évitez les manipulations ou conversions de chaînes inutiles dans la logique de comparaison. L'exemple ci-dessus montre une approche efficace qui minimise les frais généraux.
  • Cordons nuls ou vides: Votre Comparator doit gérer gracieusement null ou des chaînes vides pour empêcher NullPointerExceptions. Envisagez d'ajouter des vérifications des valeurs null et de les manipuler de manière appropriée.

y a-t-il des fonctions Java ou des bibliothèques intégrées qui simplifient le tri des chaînes alphanumériques?

Bien que Java n'ait pas de fonction intégrée spécifiquement conçue pour le tri de chaîne alphanumérique, la méthode Collections.sort(), avec une solution de coutume Comparator, une flexible. Des bibliothèques comme Apache Commons Lang offrent des utilitaires qui pourraient aider à la manipulation des cordes (par exemple, extraire des pièces numériques), mais elles ne fournissent pas directement un trieur alphanumérique prêt à l'emploi. La création d'une personnalité Comparator est généralement l'approche la plus efficace et la plus directe pour cette tâche, car elle vous permet de contrôler avec précision la logique de tri pour répondre à vos besoins spécifiques. L'utilisation de bibliothèques externes peut ajouter des frais généraux et des dépendances inutiles.

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!

Déclaration
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
Quels sont les avantages de l'utilisation de bytecode sur le code natif pour l'indépendance de la plate-forme?Quels sont les avantages de l'utilisation de bytecode sur le code natif pour l'indépendance de la plate-forme?Apr 30, 2025 am 12:24 AM

ByteCodeachievesPlatformIndependanceBeBeingExEcutedByaVirtualmachine (VM), permettant à la codétorunonanyplatformwiththeappo pourpropriév.forexample, javabytecocecanrunonanydevicewithajvm, permettre de "writeonce, runanywhere" fonctionnalité.

Java est-elle vraiment indépendante de la plate-forme à 100%? Pourquoi ou pourquoi pas?Java est-elle vraiment indépendante de la plate-forme à 100%? Pourquoi ou pourquoi pas?Apr 30, 2025 am 12:18 AM

Java ne peut pas atteindre l'indépendance de la plate-forme à 100%, mais son indépendance de la plate-forme est implémentée via JVM et ByteCode pour s'assurer que le code s'exécute sur différentes plates-formes. Les implémentations spécifiques incluent: 1. Compilation dans ByteCode; 2. Interprétation et exécution de JVM; 3. Cohérence de la bibliothèque standard. Cependant, les différences de mise en œuvre de JVM, les différences de système d'exploitation et de matériel et la compatibilité des bibliothèques tierces peuvent affecter l'indépendance de sa plate-forme.

Comment l'indépendance de la plate-forme de Java prend-elle en charge la maintenabilité du code?Comment l'indépendance de la plate-forme de Java prend-elle en charge la maintenabilité du code?Apr 30, 2025 am 12:15 AM

Java réalise l'indépendance de la plate-forme via "Écrire une fois, exécuter partout" et améliore la maintenabilité du code: 1. Réutilisation du code élevé et réduit le développement en double; 2. Coût de maintenance faible, une seule modification est requise; 3. L'efficacité de collaboration d'équipe élevée est élevée, pratique pour le partage des connaissances.

Quels sont les défis de la création d'un JVM pour une nouvelle plate-forme?Quels sont les défis de la création d'un JVM pour une nouvelle plate-forme?Apr 30, 2025 am 12:15 AM

Les principaux défis confrontés à la création d'un JVM sur une nouvelle plate-forme comprennent la compatibilité matérielle, la compatibilité du système d'exploitation et l'optimisation des performances. 1. Compatibilité matérielle: il est nécessaire de s'assurer que le JVM peut utiliser correctement l'ensemble d'instructions de processeur de la nouvelle plate-forme, tel que RISC-V. 2. Compatibilité du système d'exploitation: le JVM doit appeler correctement l'API système de la nouvelle plate-forme, comme Linux. 3. Optimisation des performances: les tests de performances et le réglage sont nécessaires, et la stratégie de collecte des ordures est ajustée pour s'adapter aux caractéristiques de la mémoire de la nouvelle plate-forme.

Comment la bibliothèque Javafx tente-t-elle de traiter les incohérences de la plate-forme dans le développement de l'interface graphique?Comment la bibliothèque Javafx tente-t-elle de traiter les incohérences de la plate-forme dans le développement de l'interface graphique?Apr 30, 2025 am 12:01 AM

Javafxefficativement adressée à la gestion de la consultation de la réalisation de temps à useraPlatform-agnosticscenegraphandcssyling.1)

Expliquez comment le JVM agit comme un intermédiaire entre le code Java et le système d'exploitation sous-jacent.Expliquez comment le JVM agit comme un intermédiaire entre le code Java et le système d'exploitation sous-jacent.Apr 29, 2025 am 12:23 AM

JVM fonctionne en convertissant le code Java en code machine et en gérant les ressources. 1) Chargement de classe: Chargez le fichier .class en mémoire. 2) Zone de données d'exécution: gérer la zone de mémoire. 3) Moteur d'exécution: interpréter ou compiler les bytecode d'exécution. 4) Interface de la méthode locale: interagir avec le système d'exploitation via JNI.

Expliquez le rôle de la machine virtuelle Java (JVM) dans l'indépendance de la plate-forme de Java.Expliquez le rôle de la machine virtuelle Java (JVM) dans l'indépendance de la plate-forme de Java.Apr 29, 2025 am 12:21 AM

JVM permet à Java de courir sur les plates-formes. 1) JVM charge, valide et exécute Bytecode. 2) Le travail de JVM comprend le chargement des classes, la vérification du bytecode, l'exécution d'interprétation et la gestion de la mémoire. 3) JVM prend en charge les fonctionnalités avancées telles que la charge de classe dynamique et la réflexion.

Quelles étapes prenez-vous pour vous assurer qu'une application Java s'exécute correctement sur différents systèmes d'exploitation?Quelles étapes prenez-vous pour vous assurer qu'une application Java s'exécute correctement sur différents systèmes d'exploitation?Apr 29, 2025 am 12:11 AM

Les applications Java peuvent s'exécuter sur différents systèmes d'exploitation via les étapes suivantes: 1) Utiliser la classe de fichiers ou de chemins pour traiter les chemins de fichier; 2) Définir et obtenir des variables d'environnement via System.getenv (); 3) Utilisez Maven ou Gradle pour gérer les dépendances et tester. Les capacités multiplateforme de Java reposent sur la couche d'abstraction de JVM, mais nécessitent toujours une manipulation manuelle de certaines caractéristiques spécifiques au système d'exploitation.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

SublimeText3 version anglaise

SublimeText3 version anglaise

Recommandé : version Win, prend en charge les invites de code !

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit