PHP双向队列


队列是一种特殊的线性表,特殊之处在于它只允许在表的前端进行删除操作,而在表的后端进行插入操作

单向队列:只能从头进,从尾出

双向队列:头尾都可以进出


<?php
/**
 * Created by PhpStorm.
 * User: Alemon °
 * Date: 2017/12/28
 */
class Queue{  
    private $queue=array();  
      
    function addFirst($item){//头入队  
        return array_unshift($this->queue,$item);  
    }  
    function addLast($item){//尾入队  
        return array_push($this->queue,$item);  
    }  
    function removeFirst(){//头出队  
        return array_shift($this->queue);  
    }  
    function removeLast(){//尾出队  
        return array_pop($this->queue);  
    }  
    function show(){//显示  
        echo implode(" ",$this->queue);  
    }  
    function clear(){//清空  
        unset($this->queue);  
    }  
    function getFirst(){  
        return array_shift($this->queue);  
    }  
    function getLast(){  
        return array_pop($this->queue);  
    }  
    function getLength(){  
        return count($this->queue);  
    }  
}  
$q=new Queue();  
$q->addFirst(1);   //头入 1
$q->addLast(5);    //尾入 5
$q->removeFirst(); //移除头一个 
$q->removeLast();  //移除尾一个
$q->addFirst(2);   //头入 2
$q->addLast(4);    //尾入 4
$q->show();        //展示



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值