Leetcode——有效的括号

方法:

bool isValid(char * s){
    Stack st;
    StackInit(&st);

    while(*s)
    {
        //左括号入栈
        if(*s == '(' || *s == '[' || *s == '{')
        {
            StackPush(&st, *s);
        }
        //右括号出栈
        else
        {
            //右括号前没有左括号
            if(StackEmpty(&st))
            {
                StackDestroy(&st);
                return false;
            }

            char tmp = StackTop(&st);
            StackPop(&st);

            //不相等则false
            if(tmp == '(' && *s != ')' 
            || tmp == '[' && *s != ']' 
            || tmp == '{' && *s != '}')
            {
                StackDestroy(&st);
                return false;
            }
        }
        s++;
    }

    //如果栈不为空,则左右括号数量不一致
    if(!StackEmpty(&st))
    {
        StackDestroy(&st);
        return false;
    }

    StackDestroy(&st);
    return true;
}

思路:

该题是给一个由左右括号组成的字符串,从左向右判断左右括号是否对应。解题思路是:如果左右括号对应,那么遍历字符串,将左括号入栈。当遇到右括号时,将字符出栈,与右括号一一比对。如果出现不对应的情况就返回false。 

需要注意的是,有可能只有左括号或者右括号的情况,要判断栈是不是空来解决左右括号数量不对应或者只有右括号的情况。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值