Valid Parenthesis String

Valid Parenthesis String

Question:请添加图片描述

思路

这个题呢, 我们首先把它当作没有*的题型.
没有*的话就简单很多了。我们只需要判断opening bracket的数量和closing bracket的数量是否一致.
balabala

加上*的题型就是多了一点儿条件, 我们在没有*的题型上面做更改.
无非就是*可以变成opening bracket/closing bracket or empty.
那就是相当于每次多了三种可能
那么我们就可以扩展一下上面那个题型的思路.
我们每次定义一个最大opening bracket的值,再定义一个最小opening bracket的值
就是说.我们可以假设* = “(”, 也可以假设* = “)”
等于"(“的情况就是 最大opening bracket增加
等于”)"的情况就是 最小opening bracket数量.

用一个leetcode的人讲解的图解释一下
请添加图片描述

我们可以看到cmin 和 cmax是我们分别定义的最大opening bracket 和 最小opening bracket的值.
一旦我们的cmin < 0 了 就说明*变成")“的可能不可行, 那就把cmin 变回0。
但是一但cmax 都 < 0 了就说明真的我们的”)" 过多了。就要return false了。

一旦cmin 最后最后 > 0, 那就说明即使把所有的* 都当作")", 也还是不够close. 那就invalid了.

class Solution {
    public boolean checkValidString(String s) {
        int cmin = 0, cmax = 0; // open parentheses count in range [cmin, cmax]
        for (char c : s.toCharArray()) {
            if (c == '(') {
                cmax++;
                cmin++;
            } else if (c == ')') {
                cmax--;
                cmin--;
            } else if (c == '*') {
                cmax++; // if `*` become `(` then openCount++
                cmin--; // if `*` become `)` then openCount--
                // if `*` become `` then nothing happens
                // So openCount will be in new range [cmin-1, cmax+1]
            }
            if (cmax < 0) return false; // Currently, don't have enough open parentheses to match close parentheses-> Invalid
                                        // For example: ())(
            cmin = Math.max(cmin, 0);   // It's invalid if open parentheses count < 0 that's why cmin can't be negative
        }
        return cmin == 0; // Return true if can found `openCount == 0` in range [cmin, cmax]
    }
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值