Maison > Java > javaDidacticiel > Comment implémenter un algorithme de tri par comptage à l'aide de Java

Comment implémenter un algorithme de tri par comptage à l'aide de Java

WBOY
Libérer: 2023-09-21 09:54:11
original
743 Les gens l'ont consulté

Comment implémenter un algorithme de tri par comptage à laide de Java

Comment implémenter un algorithme de tri par comptage en Java

Le tri par comptage est un algorithme de tri sans comparaison. Son idée principale est de compter le nombre de fois où chaque élément apparaît dans le tableau, puis de placer l'élément dans la bonne position. en fonction du nombre de fois où il apparaît. La complexité temporelle du tri par comptage est O(n+k), où n est la longueur de la séquence à trier et k est la plage du plus grand élément de la séquence à trier.

En Java, nous pouvons utiliser l'exemple de code suivant pour implémenter l'algorithme de tri par comptage :

public class CountingSort {
    public static void countingSort(int[] array) {
        int n = array.length;
        
        // 找到待排序序列中的最大值
        int max = array[0];
        for (int i = 1; i < n; i++) {
            if (array[i] > max) {
                max = array[i];
            }
        }
        
        // 创建一个计数数组,并初始化为0
        int[] count = new int[max + 1];
        for (int i = 0; i <= max; i++) {
            count[i] = 0;
        }
        
        // 统计每个元素在待排序序列中出现的次数
        for (int i = 0; i < n; i++) {
            count[array[i]]++;
        }
        
        // 根据计数数组构建有序序列
        int index = 0;
        for (int i = 0; i <= max; i++) {
            while (count[i] > 0) {
                array[index] = i;
                index++;
                count[i]--;
            }
        }
    }
    
    public static void main(String[] args) {
        int[] array = {9, 1, 5, 3, 7, 3, 8, 2, 6};
        
        System.out.println("排序前:");
        for (int num : array) {
            System.out.print(num + " ");
        }
        System.out.println();
        
        countingSort(array);
        
        System.out.println("排序后:");
        for (int num : array) {
            System.out.print(num + " ");
        }
        System.out.println();
    }
}
Copier après la connexion

Dans le code ci-dessus, nous trouvons d'abord la valeur maximale dans la séquence à trier, puis créons un tableau de comptage et ajoutons le nombre d'occurrences de chaque élément Les statistiques sont dans le tableau count. Ensuite, nous construisons une séquence ordonnée basée sur le tableau de comptage. L'opération spécifique consiste à placer les éléments du tableau de comptage dans la séquence à trier en fonction du nombre d'occurrences. Enfin, en appelant la méthode countingSort et en imprimant la séquence ordonnée, nous pouvons voir les résultats du tri par comptage.

Il convient de noter que le tri par comptage a certaines restrictions sur la plage d'éléments de la séquence à trier et n'est applicable qu'aux séquences entières non négatives. S'il y a des nombres négatifs ou des éléments d'autres types de données dans la séquence à trier, un traitement approprié est requis avant que l'algorithme de tri par comptage puisse être utilisé.

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