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


PHP SplStack::valid方法代碼示例

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


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

示例1: postorder

function postorder($tree)
{
    $lst = array();
    if (!$tree) {
        return $lst;
    }
    $stack = new SplStack();
    $stack->push($tree);
    $stack->rewind();
    $prev = null;
    while ($stack->valid()) {
        $curr = $stack->current();
        // go down the tree.
        //check if current node is leaf, if so, process it and pop stack,
        //otherwise, keep going down
        if (!$prev || @$prev->left->key == @$curr->key || @$prev->right->key == @$curr->key) {
            //prev == null is the situation for the root node
            if ($curr->left) {
                $stack->push($curr->left);
                $stack->rewind();
            } else {
                if ($curr->right) {
                    $stack->push($curr->right);
                    $stack->rewind();
                } else {
                    $stack->pop();
                    $stack->rewind();
                    $lst[] = $curr->key;
                }
            }
            //go up the tree from left node
            //need to check if there is a right child
            //if yes, push it to stack
            //otherwise, process parent and pop stack
        } else {
            if (@$curr->left->key == @$prev->key) {
                if (@$curr->right->key) {
                    $stack->push($curr->right);
                    $stack->rewind();
                } else {
                    $stack->pop();
                    $stack->rewind();
                    $lst[] = $curr->key;
                }
            } else {
                if (@$curr->right->key == @$prev->key) {
                    $stack->pop();
                    $stack->rewind();
                    $lst[] = $curr->key;
                }
            }
        }
        $prev = $curr;
    }
    return $lst;
}
開發者ID:eltonoliver,項目名稱:Algorithms,代碼行數:56,代碼來源:postorder_traversal.php

示例2: inorder

function inorder($t)
{
    $stack = new SplStack();
    $result = array();
    $p = $t;
    while ($stack->valid() || $p) {
        if ($p) {
            $stack->push($p);
            $stack->rewind();
            $p = $p->left;
        } else {
            $t = $stack->pop();
            $result[] = $t->key;
            $stack->rewind();
            $p = $t->right;
        }
    }
    return $result;
}
開發者ID:eltonoliver,項目名稱:Algorithms,代碼行數:19,代碼來源:inorder_traversal.php

示例3: log

 /**
  * Logs with an arbitrary level.
  *
  * @param string $level
  * @param string|array $message a textual message, encoded JSON or array to encode into JSON
  * @param array $context context regarding the message, if this is included it will
  *                       added to the message as json or included in the json payload
  * @throws \InvalidArgumentException
  * @return null
  */
 public function log($level, $message, array $context = array())
 {
     $this->connectIfNotConnected();
     if (is_array($message)) {
         $message = json_encode($message);
     }
     if (!is_string($message)) {
         throw new \InvalidArgumentException('the message argument needs to be a string or an array');
     } else {
         $isJson = $this->isJSON($message);
         if ($isJson) {
             $json = json_decode($message, true);
             if ("" != $this->_hostname) {
                 $json["hostname"] = $this->_hostname;
             }
             $json["level"] = $level;
             if (count($context) > 0) {
                 $json["context"] = $context;
             }
             $message = json_encode($json);
         } else {
             $message = strtoupper($level) . " - " . $message;
             if ("" != $this->_hostname) {
                 $message = "hostname={$this->_hostname} - " . $message;
                 if (count($context) > 0) {
                     $message .= " - " . json_encode($context);
                 }
             }
         }
         $this->_writer_stack->rewind();
         while ($this->_writer_stack->valid()) {
             /** @var LogEntriesWriter $writer */
             $writer = $this->_writer_stack->current();
             $message = $writer->log($message, $isJson);
             $this->_writer_stack->next();
         }
         $this->writeToSocket($this->substituteNewline($message) . PHP_EOL);
     }
 }
開發者ID:cbschuld,項目名稱:logentries,代碼行數:49,代碼來源:LogEntries.php

示例4: dealWithChildDepartmentNotMatch

 /**
  * 匹配最小子科室未匹配到科室信息的情況
  * @author gaoqing
  * 2015年11月2日
  * @param SplStack $notMatchDepartmentStack 未匹配的子科室棧
  * @param array $matchArr 已匹配的父科室數組
  * @return int 更新後的最小子科室id 
  */
 private function dealWithChildDepartmentNotMatch($notMatchDepartmentStack, $matchArr)
 {
     $currentDepartmentID = 0;
     //都未匹配時:
     $pid = 0;
     //部分匹配時:
     if (!empty($matchArr)) {
         $pid = isset($matchArr[0]) ? isset($matchArr[0][0]) ? $matchArr[0][0]['id'] : 0 : 0;
     }
     $notMatchDepartmentStack->rewind();
     while ($notMatchDepartmentStack->valid()) {
         if ($notMatchDepartmentStack->isEmpty()) {
             break;
         }
         $departmentAndLevel = $notMatchDepartmentStack->pop();
         //向 wd_keshi_test 表中,插入科室信息
         $currentDepartmentID = $pid = $this->insertKeshiInfo($departmentAndLevel, $pid);
     }
     return $currentDepartmentID;
 }
開發者ID:VampireMe,項目名稱:Common_PHP,代碼行數:28,代碼來源:MatchData.php

示例5: valid

 /**
  * Skip null elements while validated the current one.
  *
  * @return  bool
  */
 public function valid()
 {
     while (true === parent::valid() && null === $this->current() && null === parent::next()) {
     }
     return parent::valid();
 }
開發者ID:Grummfy,項目名稱:Central,代碼行數:11,代碼來源:WeakStack.php


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