遇到左括号进栈,遇到右括号出栈(如果栈里没有,说明不闭合),遍历到最后元素,判断栈内为空,即为闭合
function checkClose($str)
{
$stack = [];
for ($i = 0; $i < strlen($str); ++$i) {
if ($str[$i] == "(") {
$stack[] = "(";
}
if ($str[$i] == ")") {
$border = array_pop($stack);
if(!$border) {
return false;
}
}
}
if (count($stack) == 0) {
return true;
}
return false;
}
var_dump(checkClose('(())'));
var_dump(checkClose('(())()(('));
var_dump(checkClose('(())()()'));
var_dump(checkClose('(())()))'));
var_dump(checkClose('(5+2)*6/(3-1)'));

本文介绍了一种使用栈数据结构检查括号是否正确闭合的算法。通过遍历字符串,遇到左括号将其压入栈中,遇到右括号则尝试从栈中弹出左括号进行配对。最后检查栈是否为空来确定括号是否全部闭合。
256

被折叠的 条评论
为什么被折叠?



