LeetCode921:使括号有效的最少添加

110 篇文章 0 订阅

给定一个由 '(' 和 ')' 括号组成的字符串 S,我们需要添加最少的括号( '(' 或是 ')',可以在任何位置),以使得到的括号字符串有效。

从形式上讲,只有满足下面几点之一,括号字符串才是有效的:

  • 它是一个空字符串,或者
  • 它可以被写成 AB (A 与 B 连接), 其中 A 和 B 都是有效字符串,或者
  • 它可以被写作 (A),其中 A 是有效字符串。

给定一个括号字符串,返回为使结果字符串有效而必须添加的最少括号数。

示例 1:

输入:"())"
输出:1

示例 2:

输入:"((("
输出:3

示例 3:

输入:"()"
输出:0

示例 4:

输入:"()))(("
输出:4

提示:

  1. S.length <= 1000
  2. S 只包含 '(' 和 ')' 字符。

解析:

    题目中给的示例比较多,其实只要自己考虑全面所有的情况就可以了。输入"("时,直接压栈,输入")"时,判断栈中是否有元素,如果有,则弹出,否则count值加1。最后,栈中可能还会存在“(”括号。因此需要将count和栈的size()加起来。

代码:

int minAddToMakeValid(string S) 
{
	stack<char> cStack;
	if (S.length() == 0)
		return 0;
	int count = 0;
	for (auto c : S)
	{
		if (c == '(')
			cStack.push(c);
		else
		{
			if (cStack.empty())
				count++;
			else
				cStack.pop();
		}
	}
	return cStack.size() + count;
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值