51nod 1476 括号序列的最小代价【贪心】【堆】
来源:互联网 发布:unity3d角色动画模型 编辑:程序博客网 时间:2024/06/06 01:15
Description
这里有一个关于合法的括号序列的问题。
如果插入“+”和“1”到一个括号序列,我们能得到一个正确的数学表达式,我们就认为这个括号序列是合法的。例如,序列”(())()”, “()”和”(()(()))”是合法的,但是”)(“, “(()”和”(()))(“是不合法的。我们这有一种仅由“(”,“)”和“?”组成的括号序列,你必须将“?”替换成括号,从而得到一个合法的括号序列。
对于每个“?”,将它替换成“(”和“)”的代价已经给出,在所有可能的变化中,你需要选择最小的代价。
题解
一个括号序列合法当且仅当把’(‘看成1,’)’看成-1后所有前缀和都大于0,且总和为0。
这样,我们考虑每次都把’)’变成右括号,如果前缀和小于0了,就要把某一个右括号改成左括号,我们一定是把改成左括号后答案增量最小的右括号修改成左括号,用一个优先队列维护就可以了。
代码
#include<cstdio>#include<cstring>#include<algorithm>#include<queue>#define maxn 50006#define LL long longusing namespace std;int n,m,cnt,x[maxn],y[maxn],id[maxn];LL ans;char a[maxn];priority_queue < LL > heap;int main(){ freopen("cost.in","r",stdin); freopen("cost.out","w",stdout); char ch=getchar(); while(ch!='\n'){ a[++n]=ch; if(a[n]=='?')id[n]=++m; ch=getchar(); } for(int i=1;i<=m;i++)scanf("%d%d",&x[i],&y[i]); for(int i=1;i<=n;i++) if(a[i]=='(')cnt++;else if(a[i]==')'){ cnt--; if(cnt<0){ if(heap.empty())return printf("-1"),0; ans-=heap.top();heap.pop();cnt+=2; } }else if(a[i]=='?'){ cnt--;ans+=y[id[i]];heap.push(y[id[i]]-x[id[i]]); if(cnt<0)ans-=heap.top(),heap.pop(),cnt+=2; } if(cnt!=0)return printf("-1"),0; printf("%lld\n",ans); return 0;}
阅读全文
0 0
- 51nod 1476 括号序列的最小代价【贪心】【堆】
- 【贪心】51Nod 1476 括号序列的最小代价
- 51nod 1476 括号序列的最小代价
- 51Nod-1476-括号序列的最小代价
- 51nod 1476 括号序列的最小代价
- 51node1476 括号序列的最小代价(贪心)
- [贪心] 51Nod1476 括号序列的最小代价
- 【51Nod1476】括号序列的最小代价
- 括号序列的最小代价
- 51nod 1125[交换机器的最小代价]【贪心】
- 优先队列+括号配对 51Nod1476 括号序列的最小代价
- 51NOD 1125(交换机器最小代价) (贪心) 思想 !思想!
- 51nod 1125 机器交换最小代价(贪心)
- 51 nod 1125 交换机器的最小代价(强连通分量+贪心)
- 51nod 1125 交换机器的最小代价 (贪心 公式)
- 51nod 1255 字典序最小的子序列【贪心】
- 51nod 1255 字典序最小的子序列 []【贪心】
- 51NOD 1255 字典序最小的子序列 【贪心】
- 线性表的顺序储存(顺序表)
- angularja修改密码
- [2017纪中10-21]Dark DP
- [思维题]51 Nod 1671——货物运输
- lda plda主题模型
- 51nod 1476 括号序列的最小代价【贪心】【堆】
- 洛谷 1967 [NOIP2013] 货车运输 最大生成树+倍增
- leetcode_645. Set Mismatch ? 待解决
- 把时间当作朋友(笔记)——管理
- LightOJ
- angular Js删除
- Tyvj4620:一方的loli量产计画 (快速幂)
- pinpoint
- css3选择器汇总