本文整理匯總了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;
}
示例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;
}
示例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);
}
}
示例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;
}
示例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();
}