• php 双向队列


    <?php
    /**
     * User: kevin
     * Date: 2020-10-28
     * Time: 10:50
    */
    /**
     * PHP实现双向队列,双端队列
     * 双端队列(deque,全名double-ended queue)是一种具有队列和栈性质的数据结构。
     * 双端队列中的元素可以从两端弹出,插入和删除操作限定在队列的两边进行。
     */
    class Deque
    {
        public $queue=array();
        /**
         * 构造函数初始化队列
         */
        public function __construct($queue=array())
        {
            if(is_array($queue))
            {
                $this->queue=$queue;
            }
        }
        /**
         * 获取第一个元素
         */
        public function front()
        {
            return reset($this->queue);
        }
        /**
         * 获取最后一个元素
         */
        public function back()
        {
            return end($this->queue);
        }
        /**
         * 判断是否为空
         */
        public function is_empty()
        {
           return empty($this->queue);
        }
        /**
         * 队列大小
         */
        public function size()
        {
           return count($this->queue);
        }
        /**
         * 插入到尾
         */
        public function push_back($val)
        {
            array_push($this->queue,$val);
        }
        /**
         * 插入到头
         */
        public function push_front($val)
        {
           array_unshift($this->queue,$val);
        }
        /**
         * 移除最后一个元素
         */
        public function pop_back()
        {
           return array_pop($this->queue);
        }
        /**
         * 移除第一个元素
         */
        public function pop_front()
        {
            return array_shift($this->queue);
        }
        /**
         * 清空队列
         */
        public function clear()
        {
            $this->queue=array();
        }
    }
    //初始化一个双向队列
    $deque=new Deque(array(1,2,3,4,5));
    echo $deque->size().PHP_EOL;
    echo $deque->is_empty().PHP_EOL;
    echo $deque->front().PHP_EOL;
    echo $deque->back().PHP_EOL;
    echo PHP_EOL;
    //弹出元素测试
    echo $deque->pop_back().PHP_EOL;
    echo $deque->pop_front().PHP_EOL;
    echo $deque->size().PHP_EOL;
    echo PHP_EOL;
    $deque->push_back('a').PHP_EOL;
    $deque->push_front(0).PHP_EOL;
    echo PHP_EOL;
    //插入测试
    echo $deque->front().PHP_EOL;
    echo $deque->back().PHP_EOL;
    echo $deque->size().PHP_EOL;
    echo PHP_EOL;
    //清空测试
    $deque->clear();
    echo $deque->is_empty();
    

      

  • 相关阅读:
    【BZOJ4637】期望 Kruskal+矩阵树定理
    IEnumerable是什么
    (转)IIS windows认证
    使用pgrouting进行最短路径搜索
    Nginx设置防止IP及非配置域名访问
    java 调用c# web api 代码
    一台机器部署多个tomcat服务 nginx反向代理多个服务 笔记
    利用Kettle 从Excel中抽取数据写入SQLite
    sql server 统计信息
    sql server 索引碎片相关问题
  • 原文地址:https://www.cnblogs.com/kevin-yang123/p/13889738.html
Copyright © 2020-2023  润新知