括号序列 Scala题解 附Java代码

括号序列

题目描述:给出一个仅包含字符'(',')','{','}','['']',的字符串,判断给出的字符串是否是合法的括号序列
括号必须以正确的顺序关闭,"()""()[]{}"都是合法的括号序列,但"(]""([)]"不合法。
**示例1**
输入
"["
返回值
false
**示例2**
输入
"[]"
返回值
true

scala题解

def isValid(s:String): Boolean ={
    //定义一个栈
    val stack = mutable.Stack[Character]()
    //遍历括号序列
    for(index<-0 to s.length-1){
      //当前位置的字符
      val ch = s.charAt(index)
      //如果是空栈的话,不需要判断,直接入栈即可
      if(stack.isEmpty){
        stack.push(ch)
      }else{
        //取出栈顶元素
        val peek = stack.head
        //如果栈顶元素和当前位置的括号能成为一个组合,那么将栈顶元素消掉
        if((peek=='('&&ch==')'||(peek=='['&&ch==']')||(peek=='{'&&ch=='}'))){
          stack.pop
        }else if(ch==']'||ch=='}'||ch==')'){
          //如果栈顶元素和当前元素不能构成一个组合,而且当前元素是右括号,那么该括号序列不成立
          return false
        }else{
          //该情况是括号嵌套,左括号之前没有右括号,可以直接入栈
          stack.push(ch)
        }
      }
    }
    //如果该栈元素都被消除掉,当前栈为空,为符合的括号序列
    stack.isEmpty
  }

随带附个Java代码:

public boolean isValid (String s) {
    Stack<Character> stack = new Stack<>();
    for(int i=0;i<s.length();i++){
      char ch = s.charAt(i);
      if(!stack.isEmpty()){
        char top = stack.peek();
        if((top=='('&&ch==')')||(top=='{'&&ch=='}')||(top=='['&&ch==']'))
          stack.pop();
        else if(ch==')'||ch==']'||ch=='}')
          return false;
        else stack.push(ch);
      }else{
        stack.push(ch);
      }
    }
    return stack.isEmpty();
  }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值