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.
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 :
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
结构体,其中包含了循环队列的数据和操作方法。通过构造函数Constructor
initialiser, 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!