算法题【一】最大括号深度(java实现)

   问题:

代码:

import static java.lang.Math.max;

public class test1{
    public static void main(String[] args) {
        Integer dep = maxDepth("{}()[]((()){})");
        System.out.println(dep);//打印结果为3
    }
    public static Integer maxDepth(String brackets){
        String bracketsCopy = brackets;
        int leng = brackets.length();
        //1.如果括号不是成对出现,是无效字符串
        if(leng%2 !=0) {
            return 0;
        }
        //2. 判断括号是否是一一对应
        int num = leng/2;
        while(num > 0){
            bracketsCopy = bracketsCopy.replace("{}","").replace("[]","").replace("()","");
            num --;
        }
        int depth = 0;
        int zuokuohao = 0;
        int youkuohao = 0;
        //3. 如果同时满足一一对应,换算成同一种括号计算
        if(bracketsCopy.length() ==0){
            brackets = brackets.replace('{','(').replace('}',')').replace('[','(').replace(']',')');
            for(int i=0;i<leng;i++){
                if(brackets.charAt(i) =='('){
                    zuokuohao ++;
                }else if(brackets.charAt(i) ==')'){
                    youkuohao++;
                }
                depth = max(depth, zuokuohao-youkuohao);
            }
           return depth;
        }else{
            return 0;
        }
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值