dongyue6199 2013-11-26 06:50
浏览 39
已采纳

PHP堆栈实现

I want to construct a stack implemented in PHP. Initially I have this code:

class Stack
{
    protected $stack;
    protected $limit;

    public function __construct($limit = 10) {
        // initialize the stack
        $this->stack = array();
        // stack can only contain this many items
        $this->limit = $limit;
    }

    public function push($item) {
        // trap for stack overflow
        if (count($this->stack) < $this->limit) {
            // prepend item to the start of the array
            array_unshift($this->stack, $item);
        } else {
            throw new RunTimeException('Stack is full!');
        }
    }

    public function pop() {
        if ($this->isEmpty()) {
            // trap for stack underflow
          throw new RunTimeException('Stack is empty!');
      } else {
            // pop item from the start of the array
            return array_shift($this->stack);
        }
    }

    public function top() {
        return current($this->stack);
    }

    public function isEmpty() {
        return empty($this->stack);
    }
}

And initialize the class normally using this:

$stack = new Stack();
$stack->push(1);
$stack->push(2);
$stack->push(3);
$stack->push(4);
$stack->push(5);

This is correct and running. However, I want to initialize my stack with an initial value like this:

$stack = new Stack(array(1,2,3,4,5));

How can I implement this?


Note that all other functions (e.g pop and push) are functional.

  • 写回答

5条回答 默认 最新

  • dprxj1995 2013-11-26 07:00
    关注

    Change your constructor as follows:

    <?php
    
    class Stack {
    
        protected $stack;
        protected $limit;
    
        public function __construct($limit = 10, $initial = array()) {
            // initialize the stack
            $this->stack = $initial;
            // stack can only contain this many items
            $this->limit = $limit;
        }
    
        public function push($item) {
            // trap for stack overflow
            if (count($this->stack) < $this->limit) {
                // prepend item to the start of the array
                array_unshift($this->stack, $item);
            } else {
                throw new RunTimeException('Stack is full!');
            }
        }
    
        public function pop() {
            if ($this->isEmpty()) {
                // trap for stack underflow
                throw new RunTimeException('Stack is empty!');
            } else {
                // pop item from the start of the array
                return array_shift($this->stack);
            }
        }
    
        public function top() {
            return current($this->stack);
        }
    
        public function isEmpty() {
            return empty($this->stack);
        }
    
    }
    
    /**
     * This'll work as expected.
     */
    $stack = new Stack();
    $stack->push(1);
    $stack->push(2);
    $stack->push(3);
    $stack->push(4);
    $stack->push(5);
    
    /**
     * And this too.
     */
    $stack = new Stack(10, array(1, 2, 3, 4, 5));
    

    Just FYI, PHP has array_push (http://php.net/manual/en/function.array-push.php) and array_pop (http://us3.php.net/array_pop) implementations.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 在不同的执行界面调用同一个页面
  • ¥20 基于51单片机的数字频率计
  • ¥50 M3T长焦相机如何标定以及正射影像拼接问题
  • ¥15 keepalived的虚拟VIP地址 ping -s 发包测试,只能通过1472字节以下的数据包(相关搜索:静态路由)
  • ¥20 关于#stm32#的问题:STM32串口发送问题,偶校验(even),发送5A 41 FB 20.烧录程序后发现串口助手读到的是5A 41 7B A0
  • ¥15 C++map释放不掉
  • ¥15 Mabatis查询数据
  • ¥15 想知道lingo目标函数中求和公式上标是变量情况如何求解
  • ¥15 关于E22-400T22S的LORA模块的通信问题
  • ¥15 求用二阶有源低通滤波将3khz方波转为正弦波的电路