题解 | #切糕#

切糕

https://ac.nowcoder.com/acm/problem/233244

#include<bits/stdc++.h>
#define io ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)
using namespace std;
typedef long long int ll;
typedef pair<int,int> PII;
#define int long long

string s;
int ans=1,cnt;
int aleft=0;
bool flag=true; //判断下字符串的合法性
const int mod = 1e9+7;
signed main()    
{
    getline(cin,s);
    
    for(int i=0;i<s.size();i++)
    {
        if(s[i] == '(')aleft++;//模拟栈,左括号入栈    
        else 
        {
            if(aleft) aleft--;//如果栈不为空则可以匹配,出栈匹配
            else//不合法咯
            {
                flag=false;
                break;
            }
        }
        //一次匹配完,说明找到一个可以切的位置了 ->>值得一提,此时left一定会为0
        if(!aleft) cnt++;
        
    }
    if(aleft) flag=false; //多判断一种情况,就是不为空也是不合法的,比如(((((
    
    if(!flag)puts("-1");
    else
    {
        cnt-=1;//减1是因为最后一个括号右边不是一种切法,尽管此时是合法的入栈出栈
        
        while(cnt--)
        {
            ans%=mod;
            ans*=2;//一个合法的位置可以切也可以不切,所以cnt个位置有cnt*2种方法
            ans%=mod;
        }
        ans%=mod;
        cout<<ans<<endl;
    }
    return 0;
}
全部评论

相关推荐

01-14 10:23
已编辑
湖南师范大学 计调
太久没更新,前几天看到一条评论,说“牛客就是当年那群做题区毕业了开始找工作还收不住那股味”的群体。字里行间透着居高临下的评判,不是,他该不会以为自己很幽默?很犀利吧?作为在牛客混了不算短日子的用户,我感到的不只是被冒犯,更是一种深刻的悲哀——这种以“松弛感”为名,对另一种生存策略的轻蔑,颇有一种自己考不上大学早早出来混社会,嘲笑考上大学的人是书呆子,然后大言不惭地说:死读书有什么用,人脉和资源才是硬道理。我不知道说这个话的人,手头究竟握着多少真正管用的人脉与资源,也不知道他这么傲慢地说出“那股味”的时候,是站在哪一个巨人的肩膀上,才能如此“松弛从容”地俯视众生,还能品评出别人身上“没收住”的余...
淬月星辉:这种评论把正常的努力扭曲成卷😂,说白了就是自己不努力,看着身边努力的人一个个都事业有成了,自己的心里开始不平衡了,就发这种酸言酸语。牛客可以说是我用过那么多平台里社区氛围最好的论坛了,用了大半年了,基本上没见过有人吵架的,都是在互帮互助提建议,帮忙看简历的,帮忙选offer的,帮忙指点学习路线的,分享工作经验和趣事的,我觉得这才是互联网该有的样子。
点赞 评论 收藏
分享
喵_coding:这实习干啥了? 没写出来一点产出啊 好好回忆一下干了啥 问问ai 问问大佬 准备些话术就好了
点赞 评论 收藏
分享
之前自己不懂事,投了字节,基本是自己第一次面试,一面就挂了
观水:前几天有个学化学的做前端,加上实习面了22次字节最后成功了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务