package main
import ("fmt"
"os"
"errors"
)
type Queue struct{
maxSize int
array [4]int
front int
rear int
}
func (this *Queue)AddQueue(val int)(err error){
if this.rear == this.maxSize -1{
return errors.New("queue full")
}
this.rear ++
this.array[this.rear] = val
return
}
func (this *Queue) GetQueue()(val int,err error){
if this.rear == this.front{
return -1, errors.New("queue empty")
}
this.front++
val = this.array[this.front]
return val, err
}
func (this *Queue) ShowQueue(){
fmt.Println("队列当前情况是:")
for i := this.front + 1; i <= this.rear; i ++{
fmt.Printf("array[%d]=%d\t", i, this.array[i])
}
}
func main(){
queue := Queue{
maxSize : 5,
front : -1,
rear : -1,
}
var key string
var val int
for{
fmt.Println("1. 输入add表示添加数据到队列")
fmt.Println("2. 输入get表示从队列获取数据")
fmt.Println("3. 输入show表示显示数据")
fmt.Println("4. 输入exit表示退出队列")
fmt.Scanln(&key)
switch key{
case "add":
fmt.Println("输入你要入队的队列数")
fmt.Scanln(&val)
err := queue.AddQueue(val)
if err != nil{
fmt.Println(err.Error())
}else{
fmt.Println("加入队列ok")
}
case "get" :
val, err := queue.GetQueue()
if err != nil{
fmt.Println(err.Error)
}else{
fmt.Println("从一个队列中取出一个数=", val)
}
case "show" :
queue.ShowQueue()
case "exit" :
os.Exit(0)
}
}
}
3万+

被折叠的 条评论
为什么被折叠?



