Maison développement back-end C++ Explication détaillée de la fonction de tri en C++

Explication détaillée de la fonction de tri en C++

Nov 18, 2023 pm 03:51 PM
c++ 详解 排序函数

Explication détaillée de la fonction de tri en C++

La fonction de tri en C++ est une fonction fonctionnelle utilisée pour trier les éléments d'un tableau ou d'un conteneur. Le tri peut être effectué par ordre croissant ou décroissant, et différents types de données tels que les types entiers, à virgule flottante et caractères peuvent être triés. Le langage C++ fournit plusieurs fonctions de tri. Cet article présentera en détail l'utilisation et les caractéristiques de ces fonctions de tri.

  1. Fonction sort()

La fonction sort() est l'une des fonctions de tri les plus couramment utilisées en C++ STL. Sa fonction est d'organiser les éléments dans un tableau ou un conteneur. L'utilisation de base de la fonction sort() est la suivante :

sort(begin, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, end est l'adresse du dernier élément + 1, donc end pointe vers l'adresse vide après le dernier élément. La fonction sort() trie par ordre croissant par défaut. Si vous devez trier par ordre décroissant, vous pouvez transmettre un pointeur de fonction ou une expression lambda comme troisième paramètre.

Ce qui suit est un exemple de code qui montre comment utiliser la fonction sort() pour trier un tableau d'entiers :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    sort(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

1 2 3 4 5 6 7 8 9
Copier après la connexion
Copier après la connexion
Copier après la connexion
  1. fonction stable_sort()

stable_sort () et la fonction sort( ) sont similaires, mais elles garantissent que les positions relatives des éléments ayant la même valeur restent inchangées après le tri. L'utilisation de la fonction stable_sort() est similaire à la fonction sort(). Vous pouvez également transmettre un pointeur de fonction ou une expression lambda comme troisième paramètre. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    stable_sort(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

1 2 3 4 5 6 7 8 9
Copier après la connexion
Copier après la connexion
Copier après la connexion
  1. fonction partielle_sort()

la fonctionpartial_sort() peut trier partiellement les éléments du tableau ou du conteneur, c'est-à-dire disposez les k premiers éléments les plus petits du tableau devant (ou triez les k premiers éléments les plus grands devant le tableau). L'utilisation est la suivante :

partial_sort(begin, middle, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, end est l'adresse du dernier élément + 1 et middle est un itérateur pointant vers le k-ème élément. Il convient de noter que la fonction partial_sort() garantit uniquement que les k premiers éléments sont ordonnés et que l'ordre des éléments restants n'est pas défini. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    int k = 3;

    partial_sort(arr, arr + k, arr + n);

    for (int i = 0; i < k; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

1 2 3
Copier après la connexion
  1. nth_element() fonction

nth_element() est utilisée pour sélectionner le kième plus petit (ou kième plus grand) élément dans le tableau ou le conteneur, et disposez-le à la k-ième position dans le tableau. L'utilisation est la suivante :

nth_element(begin, middle, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, end est l'adresse du dernier élément + 1 et middle est un itérateur pointant vers le k-ième élément. Il convient de noter que la fonction nth_element() garantit uniquement que les k premiers éléments du tableau sont ordonnés, tandis que le kème élément n'est pas trié. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    int k = 3;

    nth_element(arr, arr + k - 1, arr + n);

    cout << "第 " << k << " 小的数是:" << arr[k - 1] << endl;

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

第 3 小的数是:3
Copier après la connexion
  1. fonction make_heap()

la fonctionmake_heap() peut convertir un tableau ou un conteneur en un tas, c'est-à-dire le les éléments du tableau suivent les règles d'un tas binaire trié pour prendre en charge les opérations de tas. L'utilisation est la suivante :

make_heap(begin, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, et end est l'adresse du dernier élément + 1. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

9 7 8 6 4 3 5 1 2
Copier après la connexion
  1. fonctionpush_heap()

la fonctionpush_heap() peut insérer un nouvel élément dans le tas et réajuster la structure du tas pour satisfaire la nature du tas. L'utilisation est la suivante :

push_heap(begin, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, et end est l'adresse du dernier élément. Il convient de noter que le nouvel élément inséré doit être placé à la dernière position du tas. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    arr[n] = 0;

    push_heap(arr, arr + n + 1);

    for (int i = 0; i < n + 1; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

9 7 8 6 4 3 5 1 2 0
Copier après la connexion
  1. fonction pop_heap()

la fonction pop_heap() est utilisée pour faire apparaître l'élément supérieur du tas et le réajuster. la structure du tas pour répondre à la nature du tas. L'utilisation est la suivante :

pop_heap(begin, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, et end est l'adresse du dernier élément. Il convient de noter qu'après avoir fait éclater l'élément supérieur du tas, la taille du tas doit être réduite de 1. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    pop_heap(arr, arr + n);

    n--;

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

8 7 5 6 4 3 2 1
Copier après la connexion
  1. Fonction sort_heap()

La fonction sort_heap() est utilisée pour trier le tas et s'assurer que le tableau trié est dans ordre croissant. L'utilisation est la suivante :

sort_heap(begin, end);
Copier après la connexion

où start est l'adresse du premier élément du tableau ou du conteneur, et end est l'adresse du dernier élément. Il convient de noter que la fonction sort_heap() appellera d'abord la fonction pop_heap() pour faire apparaître l'élément supérieur du tas avant de trier le tas, donc la taille du tableau trié doit être réduite de 1. Voici un exemple de code :

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    sort_heap(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Copier après la connexion

Le résultat de l'exécution du code ci-dessus est le suivant :

1 2 3 4 5 6 7 8 9
Copier après la connexion
Copier après la connexion
Copier après la connexion

Résumé

Cet article présente en détail les fonctions de tri courantes en C++, notamment sort(), stable_sort(), partial_sort( ), nth_element(), make_heap(), push_heap(), pop_heap() et sort_heap(). Chacune de ces fonctions de tri possède ses propres caractéristiques et peut répondre à différents besoins de tri. Dans la programmation réelle, il est très important de choisir la fonction de tri appropriée en fonction de la situation spécifique.

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

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

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)

Conception sécurisée de structures de données en programmation simultanée C++ ? Conception sécurisée de structures de données en programmation simultanée C++ ? Jun 05, 2024 am 11:00 AM

Dans la programmation simultanée C++, la conception sécurisée des structures de données est cruciale : Section critique : utilisez un verrou mutex pour créer un bloc de code qui permet à un seul thread de s'exécuter en même temps. Verrouillage en lecture-écriture : permet à plusieurs threads de lire en même temps, mais à un seul thread d'écrire en même temps. Structures de données sans verrouillage : utilisez des opérations atomiques pour assurer la sécurité de la concurrence sans verrous. Cas pratique : File d'attente thread-safe : utilisez les sections critiques pour protéger les opérations de file d'attente et assurer la sécurité des threads.

La disposition des objets C++ est alignée sur la mémoire pour optimiser l'efficacité de l'utilisation de la mémoire La disposition des objets C++ est alignée sur la mémoire pour optimiser l'efficacité de l'utilisation de la mémoire Jun 05, 2024 pm 01:02 PM

La disposition des objets C++ et l'alignement de la mémoire optimisent l'efficacité de l'utilisation de la mémoire : Disposition des objets : les données membres sont stockées dans l'ordre de déclaration, optimisant ainsi l'utilisation de l'espace. Alignement de la mémoire : les données sont alignées en mémoire pour améliorer la vitesse d'accès. Le mot clé alignas spécifie un alignement personnalisé, tel qu'une structure CacheLine alignée sur 64 octets, pour améliorer l'efficacité de l'accès à la ligne de cache.

Comment implémenter le Strategy Design Pattern en C++ ? Comment implémenter le Strategy Design Pattern en C++ ? Jun 06, 2024 pm 04:16 PM

Les étapes pour implémenter le modèle de stratégie en C++ sont les suivantes : définir l'interface de stratégie et déclarer les méthodes qui doivent être exécutées. Créez des classes de stratégie spécifiques, implémentez l'interface respectivement et fournissez différents algorithmes. Utilisez une classe de contexte pour contenir une référence à une classe de stratégie concrète et effectuer des opérations via celle-ci.

Comment implémenter un comparateur personnalisé en C++ STL ? Comment implémenter un comparateur personnalisé en C++ STL ? Jun 05, 2024 am 11:50 AM

L'implémentation d'un comparateur personnalisé peut être réalisée en créant une classe qui surcharge Operator(), qui accepte deux paramètres et indique le résultat de la comparaison. Par exemple, la classe StringLengthComparator trie les chaînes en comparant leurs longueurs : créez une classe et surchargez Operator(), renvoyant une valeur booléenne indiquant le résultat de la comparaison. Utilisation de comparateurs personnalisés pour le tri dans les algorithmes de conteneurs. Les comparateurs personnalisés nous permettent de trier ou de comparer des données en fonction de critères personnalisés, même si nous devons utiliser des critères de comparaison personnalisés.

Similitudes et différences entre Golang et C++ Similitudes et différences entre Golang et C++ Jun 05, 2024 pm 06:12 PM

Golang et C++ sont respectivement des langages de programmation de garbage collection et de gestion manuelle de la mémoire, avec des systèmes de syntaxe et de type différents. Golang implémente la programmation simultanée via Goroutine et C++ l'implémente via des threads. La gestion de la mémoire Golang est simple et le C++ offre de meilleures performances. Dans les cas pratiques, le code Golang est plus concis et le C++ présente des avantages évidents en termes de performances.

Comment copier un conteneur STL C++ ? Comment copier un conteneur STL C++ ? Jun 05, 2024 am 11:51 AM

Il existe trois façons de copier un conteneur STL C++ : Utilisez le constructeur de copie pour copier le contenu du conteneur vers un nouveau conteneur. Utilisez l'opérateur d'affectation pour copier le contenu du conteneur vers le conteneur cible. Utilisez l'algorithme std::copy pour copier les éléments dans le conteneur.

Quels sont les principes d'implémentation sous-jacents des pointeurs intelligents C++ ? Quels sont les principes d'implémentation sous-jacents des pointeurs intelligents C++ ? Jun 05, 2024 pm 01:17 PM

Les pointeurs intelligents C++ implémentent une gestion automatique de la mémoire via le comptage de pointeurs, des destructeurs et des tables de fonctions virtuelles. Le nombre de pointeurs garde une trace du nombre de références et lorsque le nombre de références tombe à 0, le destructeur libère le pointeur d'origine. Les tables de fonctions virtuelles permettent le polymorphisme, permettant d'implémenter des comportements spécifiques pour différents types de pointeurs intelligents.

Comment implémenter une programmation multithread C++ basée sur le modèle Actor ? Comment implémenter une programmation multithread C++ basée sur le modèle Actor ? Jun 05, 2024 am 11:49 AM

Implémentation de programmation multithread C++ basée sur le modèle Actor : créez une classe Actor qui représente une entité indépendante. Définissez la file d'attente des messages dans laquelle les messages sont stockés. Définit la méthode permettant à un acteur de recevoir et de traiter les messages de la file d'attente. Créez des objets Actor et démarrez des threads pour les exécuter. Envoyez des messages aux acteurs via la file d'attente des messages. Cette approche offre une simultanéité, une évolutivité et une isolation élevées, ce qui la rend idéale pour les applications devant gérer un grand nombre de tâches parallèles.

See all articles