當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Stack::last方法代碼示例

本文整理匯總了PHP中Stack::last方法的典型用法代碼示例。如果您正苦於以下問題:PHP Stack::last方法的具體用法?PHP Stack::last怎麽用?PHP Stack::last使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Stack的用法示例。


在下文中一共展示了Stack::last方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: rewind

 /**
  * @link http://php.net/manual/en/iterator.rewind.php
  * @return void
  */
 function rewind()
 {
     $this->stack = new LinkedStack();
     $this->pushLeft($this->root);
     if (!$this->stack->isEmpty()) {
         $this->node = $this->stack->last();
         $this->key = 0;
     }
 }
開發者ID:RadekDvorak,項目名稱:Ardent,代碼行數:13,代碼來源:InOrderIterator.php

示例2: next

 /**
  * @link http://php.net/manual/en/iterator.next.php
  * @return void
  */
 function next()
 {
     /**
      * @var BinaryTree $node
      */
     $node = $this->stack->pop();
     $this->pushIfNotNull('right', $node);
     $this->pushIfNotNull('left', $node);
     if ($this->stack->isEmpty()) {
         $this->value = $this->key = null;
         return;
     }
     $this->value = $this->stack->last();
     $this->key++;
 }
開發者ID:pramoddas,項目名稱:Ardent,代碼行數:19,代碼來源:PreOrderIterator.php

示例3: next_right

 private function next_right()
 {
     $right = $this->value->right();
     if ($right !== null && !$this->stack->isEmpty() && $right === $this->stack->last()) {
         $this->stack->pop();
         $this->next_push($right);
     } else {
         $this->next_set();
     }
 }
開發者ID:pramoddas,項目名稱:Ardent,代碼行數:10,代碼來源:PostOrderIterator.php

示例4: nfx

 public function nfx($expr)
 {
     $index = 0;
     $stack = new Stack();
     $output = array();
     // postfix form of expression, to be passed to pfx()
     // $expr = trim(strtolower($expr));
     $expr = trim($expr);
     $ops = array('+', '-', '*', '/', '^', '_');
     $ops_r = array('+' => 0, '-' => 0, '*' => 0, '/' => 0, '^' => 1);
     // right-associative operator?
     $ops_p = array('+' => 0, '-' => 0, '*' => 1, '/' => 1, '_' => 1, '^' => 2);
     // operator precedence
     $expecting_op = false;
     // we use this in syntax-checking the expression
     // and determining when a - is a negation
     if (preg_match("/[^\\w\\s+*^\\/()\\.,-]/", $expr, $matches)) {
         // make sure the characters are all good
         return $this->trigger("illegal character '{$matches[0]}'");
     }
     while (1) {
         // 1 Infinite Loop ;)
         $op = substr($expr, $index, 1);
         // get the first character at the current index
         // find out if we're currently at the beginning of a number/variable/function/parenthesis/operand
         $ex = preg_match('/^([A-Za-z]\\w*\\(?|\\d+(?:\\.\\d*)?|\\.\\d+|\\()/', substr($expr, $index), $match);
         //===============
         if ($op == '-' and !$expecting_op) {
             // is it a negation instead of a minus?
             $stack->push('_');
             // put a negation on the stack
             $index++;
         } elseif ($op == '_') {
             // we have to explicitly deny this, because it's legal on the stack
             return $this->trigger("illegal character '_'");
             // but not in the input expression
             //===============
         } elseif ((in_array($op, $ops) or $ex) and $expecting_op) {
             // are we putting an operator on the stack?
             if ($ex) {
                 // are we expecting an operator but have a number/variable/function/opening parethesis?
                 $op = '*';
                 $index--;
                 // it's an implicit multiplication
             }
             // heart of the algorithm:
             while ($stack->count > 0 and $o2 = $stack->last() and in_array($o2, $ops) and $ops_r[$op] ? $ops_p[$op] < $ops_p[$o2] : $ops_p[$op] <= $ops_p[$o2]) {
                 $output[] = $stack->pop();
                 // pop stuff off the stack into the output
             }
             // many thanks: http://en.wikipedia.org/wiki/Reverse_Polish_notation#The_algorithm_in_detail
             $stack->push($op);
             // finally put OUR operator onto the stack
             $index++;
             $expecting_op = false;
             //===============
         } elseif ($op == ')' and $expecting_op) {
             // ready to close a parenthesis?
             while (($o2 = $stack->pop()) != '(') {
                 // pop off the stack back to the last (
                 if (is_null($o2)) {
                     return $this->trigger("unexpected ')'");
                 } else {
                     $output[] = $o2;
                 }
             }
             if (preg_match("/^([A-Za-z]\\w*)\\(\$/", $stack->last(2), $matches)) {
                 // did we just close a function?
                 $fnn = $matches[1];
                 // get the function name
                 $arg_count = $stack->pop();
                 // see how many arguments there were (cleverly stored on the stack, thank you)
                 $output[] = $stack->pop();
                 // pop the function and push onto the output
                 if (in_array($fnn, $this->fb)) {
                     // check the argument count
                     if ($arg_count > 1) {
                         return $this->trigger("too many arguments ({$arg_count} given, 1 expected)");
                     }
                 } elseif (array_key_exists($fnn, $this->f)) {
                     if ($arg_count != count($this->f[$fnn]['args'])) {
                         return $this->trigger("wrong number of arguments ({$arg_count} given, " . count($this->f[$fnn]['args']) . " expected)");
                     }
                 } else {
                     // did we somehow push a non-function on the stack? this should never happen
                     return $this->trigger("internal error");
                 }
             }
             $index++;
             //===============
         } elseif ($op == ',' and $expecting_op) {
             // did we just finish a function argument?
             while (($o2 = $stack->pop()) != '(') {
                 if (is_null($o2)) {
                     return $this->trigger("unexpected ','");
                 } else {
                     $output[] = $o2;
                 }
                 // pop the argument expression stuff and push onto the output
             }
//.........這裏部分代碼省略.........
開發者ID:ellipsonic,項目名稱:thebuggenige_app,代碼行數:101,代碼來源:EvalMath.php

示例5: isEmpty

        } else {
            echo "stack is empty";
        }
    }
    public function isEmpty()
    {
        if ($this->index == -1) {
            return true;
        } else {
            return false;
        }
    }
    public function first()
    {
        echo $this->stackArray[$this->index];
    }
    public function last()
    {
        echo $this->stackArray[0];
    }
}
$newStack = new Stack();
$newStack->push(2);
$newStack->push(6);
$newStack->pop();
$newStack->pop();
$newStack->pop();
$newStack->isEmpty();
$newStack->first();
$newStack->last();
$newStack->getElement(1);
開發者ID:sanjidarafin,項目名稱:FTFLOOPHP,代碼行數:31,代碼來源:pochaStack.php

示例6: isEmpty

            $this->index--;
            return $element;
        }
        echo "There is no element in the quee array";
    }
    public function isEmpty()
    {
        if ($this->index == -1) {
            return true;
        } else {
            return false;
        }
    }
    public function first()
    {
        return $this->queArray[$this->index];
    }
    public function last()
    {
        return $this->queArray[0];
    }
}
$muy = new Stack(array(3, 4, 7));
$myStack = new Stack();
$myStack->push(1);
$myStack->push(4);
echo $myStack->first(), "<br>";
echo $myStack->last(), "<br>";
echo $myStack->pop(), "<br>";
echo $myStack->pop(), "<br>";
$myStack->pop();
開發者ID:sanjidarafin,項目名稱:FTFLOOPHP,代碼行數:31,代碼來源:Quee.php


注:本文中的Stack::last方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。