当前位置:Gxlcms > PHP教程 > php实现双向队列的实例

php实现双向队列的实例

时间:2021-07-01 10:21:17 帮助过:19人阅读

简单介绍一下在实际使用中,还可以有输出受限的双向队列(即一个端点允许插入和删除,另一个端点只允许插入的双向队列)和输入受限的双向队列(即一个端点允许插入和删除,另一个端点只允许删除的双向队列)。而如果限定双向队列从某个端点插入的元素只能从该端点删除,则该双向队列就蜕变为两个栈底相邻的栈了。

1.单向队列:只能从头进,从尾出
2.双向队列:头尾都可以进出

<?php
    class duilie{
        private $arr=array();        //从头进
        public function Head_in($item){
            return array_unshift($this->arr,$item);
        }        //从头出
        public function Head_out(){
            return array_shift($this->arr);
        }        //从尾进
        public function Tail_in($item){
            return array_push($this->arr,$item);
        }        //从尾出
        public function Tail_out(){
            return array_pop($this->arr);
        }        //清空队列
        public function clear(){
            unset($this->arr);
        }        //显示队列
        public function show(){
            return implode(' ',$this->arr);
        }        //获得队列队尾的值
        public function get_last(){
            return array_pop($this->arr);
        }        //获得队列队首的值
        public function get_first(){
            return array_shift($this->arr);
        }
    }    $obj=new duilie();    $obj->Tail_in('a');    $obj->Head_in('b');    $obj->Head_in('c');    $obj->Tail_out();    $arr=$obj->show();    echo $arr;?>

1.单向队列:只能从头进,从尾出
2.双向队列:头尾都可以进出

<?php
    class duilie{
        private $arr=array();        //从头进
        public function Head_in($item){
            return array_unshift($this->arr,$item);
        }        //从头出
        public function Head_out(){
            return array_shift($this->arr);
        }        //从尾进
        public function Tail_in($item){
            return array_push($this->arr,$item);
        }        //从尾出
        public function Tail_out(){
            return array_pop($this->arr);
        }        //清空队列
        public function clear(){
            unset($this->arr);
        }        //显示队列
        public function show(){
            return implode(' ',$this->arr);
        }        //获得队列队尾的值
        public function get_last(){
            return array_pop($this->arr);
        }        //获得队列队首的值
        public function get_first(){
            return array_shift($this->arr);
        }
    }    $obj=new duilie();    $obj->Tail_in('a');    $obj->Head_in('b');    $obj->Head_in('c');    $obj->Tail_out();    $arr=$obj->show();    echo $arr;?>

相关推荐:

有关双向队列类的课程推荐

如何使用php实现一个双向队列的代码实例

php 双向队列类

以上就是php实现双向队列的实例的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行