简单介绍一下在实际使用中,还可以有输出受限的双向队列(即一个端点允许插入和删除,另一个端点只允许插入的双向队列)和输入受限的双向队列(即一个端点允许插入和删除,另一个端点只允许删除的双向队列)。而如果限定双向队列从某个端点插入的元素只能从该端点删除,则该双向队列就蜕变为两个栈底相邻的栈了。
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中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号