Maison développement back-end Problème PHP Comment implémenter une file d'attente basée sur un tableau en utilisant le langage C

Comment implémenter une file d'attente basée sur un tableau en utilisant le langage C

Apr 26, 2023 am 09:13 AM

En programmation, la file d'attente est une structure de données couramment utilisée. De nombreux langages de programmation ont leurs propres implémentations de file d'attente, telles que Queue en Java et deque en Python. Cependant, en langage C, il n’existe pas d’implémentation de file d’attente prête à l’emploi. Par conséquent, en langage C, nous devons implémenter la file d'attente en définissant un tableau et en utilisant des pointeurs et d'autres astuces.

Dans cet article, nous présenterons comment implémenter une file d'attente basée sur un tableau en utilisant le langage C.

  1. Définir une structure de file d'attente

Nous pouvons implémenter des opérations de file d'attente en définissant une structure de file d'attente. Cette structure de file d'attente comprend des informations telles que la taille de la file d'attente, les pointeurs de tête et de queue, les données des éléments, etc.

#define MAX_SIZE 100

typedef struct queue {
    int size;
    int front;
    int rear;
    int data[MAX_SIZE];
} Queue;
Copier après la connexion

Dans le code ci-dessus, nous définissons une constante MAX_SIZE pour représenter la taille maximale de la file d'attente, et déclarons une file d'attente nommée Queue en définissant une structure.

Parmi eux, size représente la taille de la file d'attente, front représente le pointeur de tête de file d'attente, Rear représente le pointeur de queue de file d'attente et data est un tableau stockant des éléments.

  1. Opération d'initialisation de la file d'attente

Dans la mise en œuvre de la file d'attente, l'opération d'initialisation de la file d'attente doit être effectuée en premier pour garantir l'utilisation correcte de la file d'attente.

void init(Queue *q) {
    q->size = 0;
    q->front = 0;
    q->rear = -1;
}
Copier après la connexion

Dans le code ci-dessus, nous définissons une fonction d'initialisation init, qui accepte le pointeur q pointant vers la structure de file d'attente comme paramètre et définit la taille de la file d'attente sur 0, le pointeur de tête sur 0 et le pointeur de queue sur - 1, indiquant que la file d'attente est vide.

  1. Opération de mise en file d'attente des éléments

L'opération de mise en file d'attente consiste à placer un élément à la fin de la file d'attente. L'implémentation ici consiste à ajouter l'élément à la fin des données du tableau et à mettre à jour la position du pointeur arrière. .

int enqueue(Queue *q, int value) {
    if(q->size == MAX_SIZE) {
        return 0;
    }
    q->rear++;
    q->data[q->rear] = value;
    q->size++;
    return 1;
}
Copier après la connexion

Dans le code ci-dessus, déterminez d'abord si la file d'attente est pleine. Si elle est pleine, renvoyez 0 pour indiquer que l'insertion a échoué. Sinon, reculez d'un bit le pointeur arrière, attribuez la valeur de l'élément à la fin des données. tableau, et la taille de la file d'attente est augmentée de 1, et enfin 1 est renvoyé pour indiquer une insertion réussie.

  1. Opération de retrait d'élément de file d'attente

L'opération de retrait de file d'attente de la file d'attente consiste à retirer l'élément en tête de la file d'attente et à mettre à jour la position du pointeur avant. L'idée mise en œuvre ici est de renvoyer la valeur de l'élément à la position avant dans les données, de déplacer le pointeur avant vers l'arrière d'un bit et de mettre à jour la taille de la file d'attente en même temps.

int dequeue(Queue *q) {
    if(q->size == 0) {
        return -1;
    }
    int value = q->data[q->front];
    q->front++;
    q->size--;
    return value;
}
Copier après la connexion

Dans le code ci-dessus, déterminez d'abord si la file d'attente est vide. Si elle est vide, renvoyez -1 pour indiquer que la file d'attente est vide. Sinon, renvoyez la valeur de l'élément à l'avant des données et déplacez l'avant. pointeur en arrière d'un bit. La file d'attente diminue la taille de 1 et renvoie la valeur de l'élément.

  1. Test de l'implémentation de la file d'attente

Maintenant que nous avons implémenté diverses opérations de la file d'attente, testons-la :

#include <stdio.h>

int main() {
    Queue myQueue;
    init(&myQueue);
    enqueue(&myQueue, 1);
    enqueue(&myQueue, 2);
    enqueue(&myQueue, 3);
    printf("%d\n", dequeue(&myQueue));
    printf("%d\n", dequeue(&myQueue));
    printf("%d\n", dequeue(&myQueue));
    return 0;
}
Copier après la connexion

Dans le code de test ci-dessus, nous définissons d'abord une file d'attente nommée myQueue et utilisons la fonction init pour l'initialiser. Ensuite, nous utilisons la fonction enqueue pour insérer les numéros 1, 2 et 3 dans la file d'attente, et utilisons la fonction dequeue pour supprimer des éléments de la file d'attente et les afficher à l'écran.

Le résultat ici devrait être :

1
2
3
Copier après la connexion
  1. Résumé

Dans cet article, nous avons appris comment implémenter une file d'attente basée sur un tableau en utilisant le langage C. En définissant une structure de file d'attente et les fonctions opérationnelles associées, nous pouvons facilement ajouter, supprimer et accéder aux éléments de la file d'attente. Bien qu'il soit difficile d'utiliser des pointeurs pour implémenter des files d'attente, cette méthode peut nous aider à mieux comprendre les principes des files d'attente et est d'une grande aide dans l'apprentissage des structures de données et des algorithmes.

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
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
4 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)

Comment implémenter les files d'attente de messages (Rabbitmq, Redis) dans PHP? Comment implémenter les files d'attente de messages (Rabbitmq, Redis) dans PHP? Mar 10, 2025 pm 06:15 PM

Cet article détaille la mise en œuvre des files d'attente de messages en PHP à l'aide de RabbitMQ et Redis. Il compare leurs architectures (AMQP vs en mémoire), les fonctionnalités et les mécanismes de fiabilité (confirmations, transactions, persistance). Meilleures pratiques de conception, erreur

Quelles sont les dernières normes de codage PHP et les meilleures pratiques? Quelles sont les dernières normes de codage PHP et les meilleures pratiques? Mar 10, 2025 pm 06:16 PM

Cet article examine les normes de codage PHP actuelles et les meilleures pratiques, en se concentrant sur les recommandations PSR (PSR-1, PSR-2, PSR-4, PSR-12). Il met l'accent

Comment puis-je travailler avec les extensions de PHP et PECL? Comment puis-je travailler avec les extensions de PHP et PECL? Mar 10, 2025 pm 06:12 PM

Cet article détaille l'installation et le dépannage des extensions de PHP, en se concentrant sur PECL. Il couvre les étapes d'installation (trouver, télécharger / compilation, activer, redémarrer le serveur), dépannage des techniques (vérification des journaux, vérification de l'installation,

Comment utiliser la réflexion pour analyser et manipuler le code PHP? Comment utiliser la réflexion pour analyser et manipuler le code PHP? Mar 10, 2025 pm 06:12 PM

Cet article explique l'API de réflexion de PHP, permettant l'inspection d'exécution et la manipulation des classes, des méthodes et des propriétés. Il détaille les cas d'utilisation courants (génération de documentation, ORMS, injection de dépendance) et prévient contre la performance Overhea

PHP 8 JIT (juste à temps) Compilation: comment cela améliore les performances. PHP 8 JIT (juste à temps) Compilation: comment cela améliore les performances. Mar 25, 2025 am 10:37 AM

La compilation JIT de PHP 8 améliore les performances en compilant le code fréquemment exécuté en code machine, bénéficiant aux applications avec des calculs lourds et en réduisant les temps d'exécution.

Comment rester à jour avec l'écosystème et la communauté PHP? Comment rester à jour avec l'écosystème et la communauté PHP? Mar 10, 2025 pm 06:16 PM

Cet article explore les stratégies pour rester à jour dans l'écosystème PHP. Il met l'accent sur l'utilisation des canaux officiels, des forums communautaires, des conférences et des contributions open source. L'auteur met en évidence les meilleures ressources pour apprendre de nouvelles fonctionnalités et un

Comment utiliser les tâches asynchrones en PHP pour les opérations non bloquantes? Comment utiliser les tâches asynchrones en PHP pour les opérations non bloquantes? Mar 10, 2025 pm 04:21 PM

Cet article explore l'exécution des tâches asynchrones en PHP pour améliorer la réactivité des applications Web. Il détaille des méthodes comme les files d'attente de messages, les cadres asynchrones (Reactphp, Swoole) et les processus de fond, mettant l'accent sur les meilleures pratiques pour Efficien

Comment utiliser les techniques d'optimisation de la mémoire dans PHP? Comment utiliser les techniques d'optimisation de la mémoire dans PHP? Mar 10, 2025 pm 04:23 PM

Cet article aborde l'optimisation de la mémoire PHP. Il détaille des techniques comme l'utilisation de structures de données appropriées, d'éviter la création d'objets inutile et d'utiliser des algorithmes efficaces. Sources de fuite de mémoire communes (par exemple, connexions non clôturées, V global

See all articles