队列
1. 队列(stack)
只允许一端进行插入,在另一端删除的线性表
2. 术语
队头、队尾、空队列
3. 实列
class Queue {
private $queue = []; // 存放数组元素
private $maxSize = 10; // 队列长度
private $front = 0; // 队头
private $rear = 0; // 队尾
private $size = 0; // 当前长度
private $tag = 0; // 0删除 1插入
// 判断是否为空
public function isEmpty () {
if($front == $rear) {
return false;
}
}
// 入队
public function push($data) {
// 判断是否队列已满
if (($this->rear+1)%$this->maxSize == $this->front ) { // 队尾指针 +1取模,如 rear=9,maxSize=10,(9+1)%10 = 0
return false;
}
// 通过size判断 $this-size == $this->maxSize 则已满
// 通过tag判断 $this->front == $this->rear && tag == 1 则已满
$this->queue[$this->rear] = $data;
$this->rear = ($this->rear + 1) % $this->maxSize;
// $this->size++;
return true;
}
// 出队
public function pull() {
if($this->isEmpty()) {
return false;
}
// 通过tag判断 $this->front == $this->rear && tag == 0 则队空
unset($this->queue[$this->front]);
$this->front = ($this->front+1) % $this->maxSize;
// $this->size--;
return true;
}
// 获取所有
public function get() {
if($this->isEmpty()) {
return false;
}
return $this->queue;
}
}
$queue = new Queue();
$queue->push('1');
$queue->push('2');
$queue->push('3');
$queue->pull();
print_r($queue->get());
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律