Maison >développement back-end >Golang >Apprenez à concevoir et à exploiter des files d'attente circulaires avec le langage Go

Apprenez à concevoir et à exploiter des files d'attente circulaires avec le langage Go

王林
王林original
2024-03-24 22:45:03684parcourir

Apprenez à concevoir et à exploiter des files dattente circulaires avec le langage Go

La conception et la manipulation de files d'attente circulaires sont un problème courant dans les structures de données, et apprendre ce concept en écrivant du code dans Go vous aidera à comprendre comment fonctionnent les files d'attente circulaires et comment les implémenter. Dans cet article, nous approfondirons le concept de files d'attente circulaires et des exemples concrets d'écriture de files d'attente circulaires en langage Go. Tout d'abord, comprenons la définition et le fonctionnement de la file d'attente circulaire.

Définition et fonctionnement de la file d'attente circulaire

La file d'attente circulaire est une structure de données de file d'attente en forme d'anneau. Sa caractéristique de base est que la tête et la queue de la file d'attente sont logiquement connectées. Lorsque la queue de la file d'attente atteint la fin du tableau, s'il reste de l'espace en tête de la file d'attente, cet espace peut être utilisé pour former une boucle.

Les opérations courantes des files d'attente circulaires incluent :

  1. Enqueue : insérer des éléments à la fin de la file d'attente.
  2. Dequeue : supprimez les éléments de la tête de la file d'attente.
  3. Déterminez si la file d'attente est vide.
  4. Déterminez si la file d'attente est pleine.

Utilisez le langage Go pour implémenter une file d'attente circulaire

Ce qui suit est un exemple de code pour utiliser le langage Go pour implémenter une file d'attente circulaire :

package main

import "fmt"

type MyCircularQueue struct {
    data []int
    size int
    front int
    rear int
}

func Constructor(k int) MyCircularQueue {
    return MyCircularQueue{
        data: make([]int, k),
        size: k,
        front: 0,
        rear: 0,
    }
}

func (this *MyCircularQueue) EnQueue(value int) bool {
    if this.IsFull() {
        return false
    }
    this.data[this.rear] = value
    this.rear = (this.rear + 1) % this.size
    return true
}

func (this *MyCircularQueue) DeQueue() bool {
    if this.IsEmpty() {
        return false
    }
    this.front = (this.front + 1) % this.size
    return true
}

func (this *MyCircularQueue) Front() int {
    if this.IsEmpty() {
        return -1
    }
    return this.data[this.front]
}

func (this *MyCircularQueue) Rear() int {
    if this.IsEmpty() {
        return -1
    }
    return this.data[(this.rear - 1 + this.size) % this.size]
}

func (this *MyCircularQueue) IsEmpty() bool {
    return this.front == this.rear
}

func (this *MyCircularQueue) IsFull() bool {
    return (this.rear + 1) % this.size == this.front
}

func main() {
    obj := Constructor(3)
    fmt.Println(obj.EnQueue(1)) // true
    fmt.Println(obj.EnQueue(2)) // true
    fmt.Println(obj.EnQueue(3)) // true
    fmt.Println(obj.EnQueue(4)) // false
    fmt.Println(obj.Rear()) // 3
    fmt.Println(obj.IsFull()) // true
    fmt.Println(obj.DeQueue()) // true
    fmt.Println(obj.EnQueue(4)) // true
    fmt.Println(obj.Rear()) // 4
}

Dans ce code, nous définissons une file d'attente circulaire MyCircularQueue结构体,其中包含了循环队列的数据和操作方法。通过构造函数Constructorinitialiser, puis implémentons la mise en file d'attente, la sortie de file d'attente, les méthodes pour déterminer si la file d'attente est vide et si la file d'attente est pleine.

Grâce à cet exemple, nous pouvons clairement comprendre comment concevoir et exploiter des files d'attente circulaires en utilisant le langage Go, et avoir une compréhension approfondie des principes de mise en œuvre des files d'attente circulaires. J'espère que cet article sera utile à tout le monde pour apprendre les files d'attente circulaires et la programmation en langage Go.

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