加入收藏 | 设为首页 | 会员中心 | 我要投稿 成都站长网 (https://www.028zz.cn/)- 科技、云开发、数据分析、内容创作、业务安全!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP上实现一个双向队列例子

发布时间:2023-11-06 11:33:26 所属栏目:PHP教程 来源:网络
导读:   双端队列(deque)是由一些项的表组成的数据结构,对该数据结构可以进行下列操作:



   push(D,X) 将项X 插入到双端队列D的前端



   pop(D) 从双端队列D中删除前端
  双端队列(deque)是由一些项的表组成的数据结构,对该数据结构可以进行下列操作:
 
      push(D,X) 将项X 插入到双端队列D的前端
 
      pop(D) 从双端队列D中删除前端项并将其返回
 
      inject(D,X) 将项X插入到双端队列D的尾端
 
      eject(D) 从双端队列D中删除尾端项并将其返回
 
  PHP实现代码
 
   代码如下
 
  1
 
  class DoubleQueue  
 
  {
 
      public $queue = array();
 
 
      /**(尾部)入队  **/
 
      public function addLast($value)  
 
      {
 
          return array_push($this->queue,$value);
 
      }
 
      /**(尾部)出队**/
 
      public function removeLast()  
 
      {
 
          return array_pop($this->queue);
 
      }
 
      /**(头部)入队**/
 
      public function addFirst($value)  
 
      {
 
          return array_unshift($this->queue,$value);
 
      }
 
      /**(头部)出队**/
 
      public function removeFirst()  
 
      {
 
          return array_shift($this->queue);
 
      }
 
      /**清空队列**/
 
      public function makeEmpty()  
 
      {
 
          unset($this->queue);
 
      }
 
      /**获取列头**/
 
      public function getFirst()  
 
      {
 
          return reset($this->queue);
 
      }
 
      /** 获取列尾 **/
 
      public function getLast()  
 
      {
 
          return end($this->queue);
 
      }
 
      /** 获取长度 **/
 
      public function getLength()  
 
      {
 
          return count($this->queue);
 
      }

  }
 
  例子
 
  编写支持双端队伍的例程,每种操作均花费O(1)时间
 
   代码如下
 
  1
 
  class deque
 
  {
 
   public $queue  = array();
 
   public $length = 0;
 
   public function frontAdd($node){
 
    array_unshift($this->queue,$node);
 
    $this->countqueue();
 
   }
 
   public function frontRemove(){
 
    $node = array_shift($this->queue);
 
    $this->countqueue();
 
    return $node;
 
   }
 
   public function rearAdd($node){
 
    array_push($this->queue,$node);
 
    $this->countqueue();
 
   }
 
   public function rearRemove(){
 
    $node = array_pop($this->queue);
 

(编辑:成都站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章