LeetCode刷题进阶之平衡括号字符串的最少插入次数(1541)

一、题目
在这里插入图片描述
演示示例:
在这里插入图片描述
二、测试代码

class Solution {
    public int minInsertions(String s) {
        int need1=0,need2=0;//need1表示所需左括号数量,need2表示所需右括号数量
        for(int i=0;i<s.length();i++){
            if(s.charAt(i)=='('){
                need2+=2;//一个左括号需要两个右括号即右括号数量一定为偶数
                if(need2%2==1){//若右括号数量为奇数
                    need1++;//左括号加一
                    need2--;//右括号减一
                }
            }
            if(s.charAt(i)==')'){
                need2--;//遇见右括号将右括号数量减一
                if(need2==-1){//遇见多余的右括号时,需要插入一个左括号且将右括号数量置为1
                    need1++;
                    need2=1;
                }
            }
        }
    return need1+need2;
    }
}

三、运行情况

在这里插入图片描述
四、刷题总结

本题的主要思路:我们通过两个变量need1和need2,need1表示所需左括号数量,need2表示所需右括号数量。遍历遇见左括号时,一个左括号需要两个右括号即右括号数量一定为偶数,对右括号为奇数进行讨论;遍历遇见右括号时将右括号数量减一,遇见多余的右括号时即need2==-1,需要插入一个左括号且将右括号数量置为1。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值