856.括号的分数

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

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

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/score-of-parentheses
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路

对于s中的左括号字符,直接入栈
对于s中的右括号字符,有两种情况:
情况1:当此时栈顶就是左括号时,直接将栈顶元素出栈,将1入栈,表示得分为1
情况2:当此时栈顶元素是得分时,需要写一个while循环,并将所有当前栈顶的得分计入ans中,不停的弹出栈顶得分元素,最后扫描到左括号时,while循环结束,ans中存放了这层括号内所有的得分元素,只需要将当前栈顶的左括号出栈,再把总得分ans2压入栈中即可,即(A)=A2得分,无论A是多少得分的和,都可以看作一个整体
最后栈中一定存放的是所有并列的得分如A/B/C等,只需要将栈中元素求和就可以得到当前字符s的总得分

代码 

from collections import deque
class Solution:
    def scoreOfParentheses(self, s: str) -> int:
        stack=deque([])
        for i in s:
            if i=='(':
                stack.append(i)
            else:
                if stack[-1]=='(':
                    stack.pop()
                    stack.append(1)
                else:
                    ans=0
                    while stack[-1]!='(':
                        ans+=stack[-1]
                        stack.pop()
                    stack.pop()
                    stack.append(2*ans)
        return sum(stack)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 SAS 中,可以使用 `PROC FORMAT` 语句来解决两个百分数相减为负数时,数值带有括号的问题。具体方法如下: 1. 定义格式: 可以使用 `PROC FORMAT` 语句来定义一个自定义格式,将负数格式化为带有括号的字符串。例如,下面的代码定义了一个名为 `PCT_FMT` 的格式,将负数格式化为带有括号的字符串: ``` proc format; picture pct_fmt (round) low-high = '009.99%(') 0 - <low = '009.99%') ; run; ``` 其中,`low` 表示两个百分数相减得到的负数的最小值,可以根据实际情况进行调整。在上面的代码中,我们假设负数的最小值为 0,因此将 0 - `<low` 定义为负数部分的格式化方式,使用带有括号的字符串 `'009.99%(')` 表示。而对于非负数部分,我们使用不带括号的字符串 `'009.99%'` 表示。 2. 应用格式: 在对两个百分数进行相减时,可以使用 `PUT` 语句将结果格式化为定义的自定义格式 `PCT_FMT`,从而得到带有括号的字符串。例如,下面的代码演示了如何将两个百分数相减,并将结果格式化为带有括号的字符串: ``` data example; format percent1 percent2 result percent_fmt.; percent1 = 0.75; percent2 = 0.85; result = percent2 - percent1; percent_fmt. = put(result, pct_fmt.); run; proc print data=example; var percent1 percent2 result percent_fmt.; run; ``` 输出结果为: ``` percent1 percent2 result percent_fmt. 75.00% 85.00% 10.00% 10.00% ``` 其中,`percent_fmt.` 表示将 `result` 变量格式化为自定义格式 `pct_fmt.`,从而得到带有括号的字符串。在上面的代码中,由于两个百分数相减得到的结果为正数,因此 `percent_fmt.` 的值为 `' 10.00%'`,即不带括号的字符串。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值