856. 括号的分数
856. Score of Parentheses
题目描述
给定一个平衡括号字符串 S,按下述规则计算该字符串的分数:
- () 得 1 分。
- AB 得 A + B 分,其中 A 和 B 是平衡括号字符串。
- (A) 得 2 * A 分,其中 A 是平衡括号字符串。
LeetCode856. Score of Parentheses中等
示例 1:
输入: "()"
输出: 1
输出: 1
示例 2:
输入: "(())"
输出: 2
输出: 2
示例 3:
输入: "()()"
输出: 2
输出: 2
示例 4:
输入: "(()(()))"
输出: 6
输出: 6
提示:
- S 是平衡括号字符串,且只含有 ( 和 ) 。
- 2 <= S.length <= 50
Java 实现
import java.util.Stack; class Solution { public int scoreOfParentheses(String S) { int cur = 0; Stack<Integer> stack = new Stack<>(); for (char c : S.toCharArray()) { if (c == '(') { stack.push(cur); cur = 0; } else { cur = stack.pop() + Math.max(cur * 2, 1); } } return cur; } }
参考资料
- https://leetcode.com/problems/score-of-parentheses/
- https://leetcode-cn.com/problems/score-of-parentheses/
来源:https://www.cnblogs.com/hglibin/p/10988617.html