Leetcode856.括号的分数

题目描述

给定一个平衡括号字符串 S,按下述规则计算该字符串的分数:

  • () 得 1 分。
  • ABA + B 分,其中 A 和 B 是平衡括号字符串。
  • (A)2 * A 分,其中 A 是平衡括号字符串。

示例 1:

复制代码
输入: "()"
输出: 1

示例 2:

复制代码
输入: "(())"
输出: 2

示例 3:

复制代码
输入: "()()"
输出: 2

示例 4:

复制代码
输入: "(()(()))"
输出: 6

提示:

  1. S 是平衡括号字符串,且只含有 ()
  2. 2 <= S.length <= 50

实现思路

1.遇到左括号,需要计算该左括号内部的平衡括号字符串A的分数,我们也要先压入分数0,表示A前面的空字符串的分数;

2.遇到右括号,说明右括号内部的子平衡括号字符串A的分数已经计算出来了,我们将它弹出栈,并保存到变量v中。若v=0,则A是空串(A)的分数为 1,否则 (A) 的分数为 2v,然后将 (A) 的分数加到栈顶元素上;

3.遍历结束后,栈顶元素保存的就是 s 的分数。

实现代码

java 复制代码
class Solution {
    public int scoreOfParentheses(String s) {
        Deque<Integer> stack = new ArrayDeque<>();
        stack.push(0);
        for(int i = 0; i < s.length(); i++){
            if(s.charAt(i) == '('){
                stack.push(0);
            }else{
                int cur = stack.pop();
                stack.push(stack.pop() + Math.max(cur * 2, 1));
            }
        }
        return stack.peek(); 
    }
}
相关推荐
算法鑫探17 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
木子墨51617 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
2501_9219608518 小时前
双相自指图与弦论边界非对易性的结构同源
数据结构
Liangwei Lin19 小时前
洛谷 P3133 [USACO16JAN] Radio Contact G
数据结构·算法
锅挤21 小时前
数据结构复习(第五章):树与二叉树
数据结构
杨凯凡1 天前
【014】基本类型与包装类:缓存、相等性、NPE
java·数据结构·缓存
故事和你911 天前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
想唱rap1 天前
C++智能指针
linux·jvm·数据结构·c++·mysql·ubuntu·bash
会编程的土豆1 天前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论
疯狂打码的少年1 天前
有序线性表删除一个元素:顺序存储 vs 单链表,平均要移动多少个元素?
数据结构·算法·链表