


Explication détaillée de la méthode de tri par compartiment de l'algorithme de complétion des nombres Java
Cet article présente principalement la structure de données Java et la méthode de mise en œuvre du tri par compartiments.Il analyse en détail le concept, le principe, la méthode de mise en œuvre et les compétences opérationnelles associées du tri par compartiments avec des exemples spécifiques.Les amis dans le besoin peuvent s'y référer
.L'exemple de cet article décrit la méthode d'implémentation du tri par compartiment de la structure de données et de l'algorithme Java. Partagez-le avec tout le monde pour votre référence, comme suit :
Idée de base :
Supposons que l'entrée soit générée par un processus aléatoire [0 , M ) nombres réels uniformément répartis sur l'intervalle. Divisez l'intervalle [0, M) en n sous-intervalles (buckets) de taille égale, allouez n éléments d'entrée à ces buckets, triez les éléments dans les buckets, puis connectez les entrées du bucket 0 ≤ A[1.. n]
[Bucket - Keyword] MappingFonction
bindex=f(key) Où, bindex est le bucket Le indice du tableau B (c'est-à-dire le bucket bindex), k est la clé de la colonne à trier. La clé de l'efficacité du tri par bucket réside dans cette fonction de cartographie, qui doit faire : Si le mot-clé k1
Si la colonne à trier K= {. 49, 38, 35, 97, 76, 73, 27, 49}. Ces données sont toutes comprises entre 1 et 100. Par conséquent, nous personnalisons 10 compartiments et déterminons la fonction de mappage f(k)=k/10. Ensuite le premier mot-clé 49 sera positionné dans le 4ème bucket (49/10=4). Empilez tous les mots-clés dans des compartiments tour à tour et effectuez un tri rapide dans chaque compartiment non vide pour obtenir l'image suivante :
Tant que l'ordre de l'image ci-dessus est Sortie les données dans chaque B[i] pour obtenir une séquence ordonnée.
Le code de base de l'algorithme est le suivant :
/// <summary> /// 桶排序 /// ///如果有重复的数字,则需要 List<int>数组,这里举的例子没有重复的数字 /// </summary> /// <param name="unsorted">待排数组</param> /// <param name="maxNumber">待排数组中的最大数,如果可以提供的话</param> /// <returns></returns> static int[] bucket_sort(int[] unsorted, int maxNumber = 97) { int[] sorted = new int[maxNumber + 1]; for (int i = 0; i < unsorted.Length; i++) { sorted[unsorted[i]] = unsorted[i]; } return sorted; } static void Main(string[] args) { int[] x = {49、 38 、 35、 97 、 76、 73 、 27、 49 }; var sorted = bucket_sort(x, 97); for (int i = 0; i < sorted.Length; i++) { if (sorted[i] > 0) Console.WriteLine(sorted[i]); } Console.ReadLine(); }
Analyse des coûts de tri des seaux
Le tri par bucket utilise la relation de mappage des fonctions pour réduire presque tout le travail de comparaison. En fait, le calcul de la valeur f(k) du tri par compartiments équivaut à la division en tri rapide, qui a divisé une grande quantité de données en blocs de données fondamentalement ordonnés (seaux). Ensuite, il vous suffit d'effectuer un tri par comparaison avancé sur une petite quantité de données dans le bucket.
La complexité temporelle du tri des buckets de N mots-clés est divisée en deux parties :
(1) BoucleCalculez le bucket de chaque mot-clé Fonction de cartographie, cette fois la complexité est O(N).
(2) Utilisez l'algorithme de tri par comparaison avancé pour trier toutes les données de chaque compartiment, et sa complexité temporelle est ∑ O(Ni*logNi). Où Ni est le volume de données du i-ième compartiment.
Évidemment, la partie (2) est le facteur déterminant dans la performance du tri par seau. Minimiser le nombre de données dans le compartiment est le seul moyen d'améliorer l'efficacité (car la meilleure complexité temporelle moyenne basée sur le tri par comparaison ne peut atteindre que O(N*logN)). Par conséquent, nous devons faire de notre mieux pour atteindre les deux points suivants :
(1) La fonction de cartographie f(k) peut répartir uniformément N données dans M buckets, de sorte que chaque bucket ait [ N /M] quantité de données.
(2) Augmentez le nombre de seaux autant que possible. Dans le cas extrême, une seule donnée peut être obtenue de chaque compartiment, évitant ainsi complètement l'opération de tri par « comparaison » des données dans le compartiment. Bien sûr, ce n'est pas facile à faire. Lorsque la quantité de données est énorme, la fonction f(k) entraînera un grand nombre d'ensembles de compartiments, ce qui entraînera un grave gaspillage d'espace. Il s’agit d’un compromis entre le coût du temps et le coût de l’espace.
Pour N données à trier et M buckets, la complexité moyenne du temps de tri des buckets de [N/M] données par bucket est :
O (N)+ O(M*(N/M)*log(N/M))=O(N+N*(logN-logM))=O(N+N*logN-N*logM)
Quand N=M, c'est-à-dire dans le cas extrême, il n'y a qu'une seule donnée dans chaque bucket. La meilleure efficacité du tri par seau peut atteindre O(N).
Résumé : La complexité temporelle moyenne du tri des seaux est linéaire O(N+C), où C=N*(logN-logM). Si par rapport au même N, plus le nombre de compartiments M est grand, plus l'efficacité est élevée et la meilleure complexité temporelle atteint O(N). Bien sûr, la complexité spatiale du tri par buckets est O(N+M). Si les données d'entrée sont très volumineuses et que le nombre de buckets est également très grand, le coût de l'espace sera sans aucun doute élevé. De plus, le tri par seau est stable.
C'est-à-dire les trois points suivants :
1. Le tri au seau est stable
2. Le tri au seau est le plus rapide parmi les tris courants, meilleur que le tri rapide. Encore plus rapide... dans la plupart des cas
3. Le tri par buckets est très rapide, mais il consomme également beaucoup d'espace. C'est fondamentalement l'algorithme de tri le plus gourmand en espace
Supplément : Dans l'algorithme de recherche, la meilleure complexité temporelle de l'algorithme de recherche basé sur la comparaison est également O(logN). Par exemple, recherche binaire, arbre binaire équilibré, arbre rouge-noir, etc. Cependant, la table Hash a une efficacité de recherche de niveau linéaire O(C) (l'efficacité de recherche atteint O(1) sans conflits). Alors : l'idée de la table de hachage est-elle similaire au tri par buckets ?
En fait, le tri par buckets a des exigences particulières en matière de conditions de données. Si le tableau est grand, des centaines de millions de buckets seront évidemment alloués. impossible. Par conséquent, le tri par compartiment a ses limites et convient aux situations où l'ensemble des valeurs d'éléments n'est pas important.
【Recommandations associées】
1. Recommandation spéciale : Téléchargement de la version V0.1 de "php Programmer Toolbox"
2. Tutoriel vidéo Java gratuit
2 Analyse complète des annotations Java
.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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

Java est un langage de programmation populaire qui peut être appris aussi bien par les développeurs débutants que par les développeurs expérimentés. Ce didacticiel commence par les concepts de base et progresse vers des sujets avancés. Après avoir installé le kit de développement Java, vous pouvez vous entraîner à la programmation en créant un simple programme « Hello, World ! ». Une fois que vous avez compris le code, utilisez l'invite de commande pour compiler et exécuter le programme, et « Hello, World ! » s'affichera sur la console. L'apprentissage de Java commence votre parcours de programmation et, à mesure que votre maîtrise s'approfondit, vous pouvez créer des applications plus complexes.

Spring Boot simplifie la création d'applications Java robustes, évolutives et prêtes à la production, révolutionnant le développement de Java. Son approche "Convention sur la configuration", inhérente à l'écosystème de ressort, minimise la configuration manuelle, allo

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

Java Made Simple : Guide du débutant sur la puissance de programmation Introduction Java est un langage de programmation puissant utilisé dans tout, des applications mobiles aux systèmes d'entreprise. Pour les débutants, la syntaxe de Java est simple et facile à comprendre, ce qui en fait un choix idéal pour apprendre la programmation. Syntaxe de base Java utilise un paradigme de programmation orienté objet basé sur les classes. Les classes sont des modèles qui organisent ensemble les données et les comportements associés. Voici un exemple simple de classe Java : publicclassPerson{privateStringname;privateintage;
