社区讨论
30分求调
P10115[LMXOI Round 1] Placer参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @m2y85wl0
- 此快照首次捕获于
- 2024/11/01 12:18 去年
- 此快照最后确认于
- 2025/11/04 15:37 4 个月前
第一组全绿,后三组全红。又不能下载测试点,完全搞不懂哪里错了,求调
CPP#include<bits/stdc++.h>
using namespace std;
int main()
{//a原数组,b[i]为i位置的)与b[i]位置的(是一对,c为结果
long long n,i,j;
cin>>n;
string s;
long long a[n+1],b[n+1],c[n+1];
cin>>s;
a[0]=0;
b[0]=0;
c[0]=0;
for(i=1;i<=n;i++)
{
cin>>a[i];
c[i]=c[i-1];
b[i]=0;
if(s[i-1]==')' && i>1 && s[i-2]=='(')
b[i]=i-1;
if(s[i-1]==')' && i>1 && s[i-2]!='(')
{
j=b[i-1]-1;
if(s[j-1]=='(')
b[i]=j;
while(s[j-1]==')' && b[j-1])
j=b[j-1]-1;
if(j!=b[i-1]-1 && j!=b[i])
b[i]=j-1;
}
if(b[i] && a[i]-a[b[i]]+c[b[i]-1]>c[i])
c[i]=a[i]-a[b[i]]+c[b[i]-1];
}
cout<<c[n];
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...