php 实现给定一个只包括 ‘(‘,‘)‘,‘{‘,‘}‘,‘[‘,‘]‘ 的字符串,判断字符串是否有效

用php实现 给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效

代码如下:

//给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效
function sLeft($s)
{
    if ($s == '{' || $s == '(' || $s == '[') {
        return 1;
    } else {
        return 2;
    }
}

function isPair($p, $curr)
{
    if (($p == '{' && $curr == '}') || ($p == '[' && $curr == ']') || ($p == '(' && $curr == ')')) {
        return 1;
    } else {
        return 0;
    }
}

function string($string)
{
    $arr = [];
    $leng = strlen($string);
    for ($i=0; $i<$leng; $i++) {
        $str = substr($string, $i, 1);
        if (sLeft($str)==1) {
            array_push($arr, $str);
        } else {
            $p = array_pop($arr);
            if (isPair($p, $str)==0) {
                return '非法';
            }
        }
    }
    if (empty($arr)) {
        return "合法";
    } else {
        return "非法";
    }
}
$s= '{[[]()[]()()]}';
string($s);

思路:利用出栈入栈 检查判断是否合法有效

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值