首页 > php教程 > php手册 > 正文

PHP实现一个双向队列例子

php中文网
发布: 2016-05-25 16:46:01
原创
1633人浏览过

deque,全名double-ended queue,是一种具有队列和栈的性质的数据结构,双端队列中的元素可以从两端弹出,其限定插入和删除操作在表的两端进行,双向队列(双端队列)就像是一个队列,但是你可以在任何一端添加或移除元素.

双端队列(deque)是由一些项的表组成的数据结构,对该数据结构可以进行下列操作:

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

pop(D) 从双端队列D中删除前端项并将其返回

inject(D,X) 将项X插入到双端队列D的尾端

立即学习PHP免费学习笔记(深入)”;

eject(D) 从双端队列D中删除尾端项并将其返回

PHP实现代码如下:

全诚商城生成HTML多用户版
全诚商城生成HTML多用户版

1、什么是店中店?店中店是全诚商多用户版的一大特色,它既是独立的个体,又具有群集功能。我们做个例子说明:假设尊贵的您现实生活中租赁了一个店面,店面空间很大,您可以把您的店面分割成很多独立空间再向别人转租,这样您可以额外获得一部分租赁费用收入,借以减少你的个人租赁费用投入,还能起到活跃销售场所的气氛,俗话说:货卖一堆吗。你租赁的店面可以完全分割成很多空间向外转租,也可以自己保留一块空间为自己销售商品

全诚商城生成HTML多用户版 0
查看详情 全诚商城生成HTML多用户版
<?php 
	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)时间,代码如下:

<?php  
	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); 
	  $this->countqueue(); 
	  return $node; 
	 } 
	   
	 public function countqueue(){ 
	  $this->length = count($this->queue);     
	 } 
	} 
	$fruit = new deque(); 
	echo $fruit -> length; 
	$fruit -> frontAdd("Apple"); 
	$fruit -> rearAdd("Watermelon"); 
	echo '<pre class="brush:php;toolbar:false;">'; 
	print_r($fruit); 
	echo '
登录后复制
';    /*结果  0  deque Object  (      [queue] => Array          (              [0] => Apple              [1] => Watermelon          )      [length] => 2  )*/ 

文章链接:

随便收藏,请保留本文地址!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号