Maison Java javaDidacticiel Développement Java : comment implémenter des structures de données et des algorithmes

Développement Java : comment implémenter des structures de données et des algorithmes

Sep 21, 2023 pm 04:31 PM
java Structure de données algorithme

Développement Java : comment implémenter des structures de données et des algorithmes

Développement Java : Comment implémenter des structures de données et des algorithmes, des exemples de code spécifiques sont requis

Introduction : Les structures de données et les algorithmes sont des connaissances de base importantes en informatique et sont des compétences que tout développeur Java doit maîtriser. Cet article présentera comment implémenter des structures de données et des algorithmes courants en Java et donnera des exemples de code spécifiques.

1. Implémentation de la structure de données

  1. Array

Array est l'une des structures de données les plus simples Vous pouvez utiliser le code suivant pour créer un tableau d'entiers en Java :

int[] array = new int[5];
  1. LinkedList

Une liste chaînée est. une structure de données dynamique. Vous pouvez utiliser le code suivant pour implémenter une liste chaînée unidirectionnelle en Java :

class Node {
    int value;
    Node next;
    
    public Node(int value) {
        this.value = value;
        this.next = null;
    }
}

class LinkedList {
    Node head;
    
    public void add(int value) {
        Node newNode = new Node(value);
        
        if (head == null) {
            head = newNode;
        } else {
            Node current = head;
            while (current.next != null) {
                current = current.next;
            }
            current.next = newNode;
        }
    }
}
  1. Stack (Stack)

La pile est une structure de données dernier entré, premier sorti (LIFO). Vous pouvez utiliser ce qui suit Le code implémente une pile :

class Stack {
    int[] array;
    int top;
    
    public Stack(int size) {
        array = new int[size];
        top = -1;
    }
    
    public void push(int value) {
        if (top < array.length - 1) {
            array[++top] = value;
        }
    }
    
    public int pop() {
        if (top >= 0) {
            return array[top--];
        }
        return -1;
    }
}

2. Implémentation d'algorithmes courants

  1. Algorithme de tri

(1) Tri à bulles

Le tri à bulles est un algorithme de tri simple qui a été visité à plusieurs reprises Éléments à triés, les éléments adjacents sont comparés et les positions sont échangées jusqu'à ce qu'aucun échange ne se produise.

Ce qui suit est un exemple de code d'utilisation de Java pour implémenter le tri à bulles :

public void bubbleSort(int[] array) {
    int n = array.length;
    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - i - 1; j++) {
            if (array[j] > array[j + 1]) {
                int temp = array[j];
                array[j] = array[j + 1];
                array[j + 1] = temp;
            }
        }
    }
}

(2) Tri rapide (Tri rapide)

Le tri rapide est un algorithme de tri couramment utilisé qui divise une séquence en deux parties en sélectionnant un élément de base. , puis triez les deux parties séparément.

Ce qui suit est un exemple de code pour implémenter le tri rapide à l'aide de Java :

public void quickSort(int[] array, int left, int right) {
    if (left < right) {
        int pivot = partition(array, left, right);
        quickSort(array, left, pivot - 1);
        quickSort(array, pivot + 1, right);
    }
}

public int partition(int[] array, int left, int right) {
    int pivot = array[right];
    int i = left - 1;
    for (int j = left; j < right; j++) {
        if (array[j] < pivot) {
            i++;
            int temp = array[i];
            array[i] = array[j];
            array[j] = temp;
        }
    }
    int temp = array[i + 1];
    array[i + 1] = array[right];
    array[right] = temp;
    return i + 1;
}
  1. Algorithme de recherche

(1) Recherche binaire (Recherche binaire)

La recherche binaire est un algorithme de recherche courant qui recherche dans un tableau ordonné Spécifie le position de l'élément.

Ce qui suit est un exemple de code pour implémenter la recherche binaire à l'aide de Java :

public int binarySearch(int[] array, int target) {
    int left = 0;
    int right = array.length - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (array[mid] == target) {
            return mid;
        } else if (array[mid] < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return -1;
}

(2) Recherche linéaire (recherche linéaire)

La recherche linéaire est un algorithme de recherche simple qui compare les éléments d'un tableau un par un jusqu'à ce que l'élément cible soit trouvé ou parcourir l’ensemble du tableau.

Ce qui suit est un exemple de code d'utilisation de Java pour implémenter la recherche linéaire :

public int linearSearch(int[] array, int target) {
    for (int i = 0; i < array.length; i++) {
        if (array[i] == target) {
            return i;
        }
    }
    return -1;
}

Conclusion :

Grâce à l'introduction de cet article, nous avons appris comment implémenter des structures de données et des algorithmes courants en Java, et donné des exemples de code spécifiques. Nous espérons que les lecteurs pourront mieux comprendre et maîtriser ces connaissances par la pratique et améliorer leurs capacités de programmation.

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 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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

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

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Qu'est-ce qu'une impasse en Java et comment pouvez-vous l'empêcher? Qu'est-ce qu'une impasse en Java et comment pouvez-vous l'empêcher? Aug 23, 2025 pm 12:55 PM

ADEADLOCKINJAVAOCCURSWHENTWOORMORORETHREADSAREBLOCKEDEDFOREVERS, chaque avance pour la fourniture de laBerce-Organisation de la manière générale;

Comment utiliser facultatif en Java? Comment utiliser facultatif en Java? Aug 22, 2025 am 10:27 AM

UseOptional.Empty (), facultatif.of (), andoptional.ofnullable () toCreateOptionalistances adepsendingonwherethevaluesabsent, non null, orpossibly null.2.Checkforvalussafelyusingispresent () orpreférall

Java Persistance avec les données de printemps JPA et Hibernate Java Persistance avec les données de printemps JPA et Hibernate Aug 22, 2025 am 07:52 AM

Le noyau de SpringDatajpa et Hibernate travaillant ensemble est: 1. JPA est la spécification et Hibernate est la mise en œuvre, l'encapsulation SpringDatajpa simplifie le développement DAO; 2. 3. L'interface du référentiel hérite de JParepository pour implémenter automatiquement les méthodes CRUD et nommées de requête; 4. Requêtes complexes Utilisez @Query Annotation pour prendre en charge JPQL ou SQL native; 5. Dans Springboot, l'intégration est terminée en ajoutant des dépendances de démarrage et en configurant les sources de données et les attributs JPA; 6. Les transactions sont effectuées par @transactiona

Java Cryptography Architecture (JCA) pour le codage sécurisé Java Cryptography Architecture (JCA) pour le codage sécurisé Aug 23, 2025 pm 01:20 PM

Comprendre les composants de base JCA tels que MessagediGest, Cipher, KeyGenerator, SecureRandom, Signature, Keystore, etc., qui mettent en œuvre des algorithmes via le mécanisme du fournisseur; 2. Utilisez des algorithmes et des paramètres forts tels que SHA-256 / SHA-512, AES (clé 256 bits, mode GCM), RSA (2048 bits ou supérieur) et SecureRandom; 3. Évitez les clés à code dur, utilisez des clés pour gérer les clés et générez des clés via des mots de passe dérivés en toute sécurité tels que PBKDF2; 4. Désactiver le mode ECB, adopter des modes de chiffrement d'authentification tels que GCM, utiliser des IV aléatoires uniques pour chaque cryptage et des caissiers clairs dans le temps

Comment utiliser les classes de modèle et de correspondance en Java? Comment utiliser les classes de modèle et de correspondance en Java? Aug 22, 2025 am 09:57 AM

La classe de motif est utilisée pour compiler des expressions régulières, et la classe de correspondance est utilisée pour effectuer des opérations correspondantes sur les chaînes. La combinaison des deux peut réaliser la recherche de texte, la correspondance et le remplacement; Créez d'abord un objet Pattern via motifs.compile (), puis appelez sa méthode Matcher () pour générer une instance de correspondance. Ensuite, utilisez des matches () pour juger la correspondance complète de la chaîne, trouver () pour trouver des sous-séquences, remplacer () ou remplacerFirst () pour le remplacement. Si le habitué contient un groupe de capture, la nth de contenu du groupe peut être obtenue via le groupe (n). Dans les applications réelles, vous devez éviter les modèles de compilation répétés, faire attention aux évasions de caractères spéciales et utiliser le drapeau de modèle d'appariement selon les besoins, et finalement atteindre efficace

Les paramètres de jeu lol n'enregistrent pas après la fermeture [fixe] Les paramètres de jeu lol n'enregistrent pas après la fermeture [fixe] Aug 24, 2025 am 03:17 AM

IfleagueoflegendSettingSaren’ssaving, tryTheSesteps: 1.RunthegameasAdministrator.2.grantfullfolderpermissionstotheagueoflegendDirectory.3.Editandensuregame.cfgisn’Tread-only.4.DisableCloudsyNcfortaGamefolder.5.

'Java n'est pas reconnue' Erreur dans CMD [3 étapes simples] 'Java n'est pas reconnue' Erreur dans CMD [3 étapes simples] Aug 23, 2025 am 01:50 AM

IfjavaisnotRecognizedIncmd, assurez-vous, assurez-vous, établit, setthejava_homevariabbletothejdkpath, andddthejdk'sbinfoldertothesystemPath.restartcmdandrunjava-versiontoConfirm.

La demande n'a pas pu être effectuée en raison d'une erreur de périphérique d'E / S [6 solutions] La demande n'a pas pu être effectuée en raison d'une erreur de périphérique d'E / S [6 solutions] Aug 23, 2025 pm 02:12 PM

Ifyouencounterani / odeviceerror, tryTheSesteps: 1.restartyourcomputerAndDevice.2.replacetheusbcableorport.3.UpdateorreinstallthedevicedRiver.4.RunchkdsktofixDiskerror.5retide / satransferModeWeveNegener.6.SishignanwDredeterIndiskman de gestion.

See all articles