QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#410180 | #7894. Many Many Heads | AC_2002 | WA | 1ms | 5820kb | C++20 | 1.6kb | 2024-05-13 17:37:41 | 2024-05-13 17:37:42 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
int a[1000010];
int b[2][500010];
void solve() {
string s;
cin >> s;
stack<char> st;
int sum1 = 0, sum2 = 0, temp1 = 0, temp2 = 0;
if (s[0] == '(' || s[0] == ')') sum1 ++, a[0] = 1, st.push('(');
else sum2 ++, a[0] = 2, st.push('[');
for (int i = 1; i < s.size(); i ++ ) {
if (s[i] == '(' || s[i] == ')') {
if (st.size() == 0) {
st.push('(');
a[i] = 1;
}
else if (st.top() == '(') a[i] = -1, st.pop();
else a[i] = 1, st.push('(');
} else {
if (st.size() == 0) {
st.push('[');
a[i] = 2;
}
else if (st.top() == '[') a[i] = -2, st.pop();
else a[i] = 2, st.push('[');
}
}
// memset(b, 0, sizeof b);
int d = 0;
int flag = 0;
for (int i = 0; i < s.size(); i ++ ) {
if (a[i] == 1) {
d ++ ;
if (b[0][d] == 1) {
flag = 1;
b[0][d] = 0;
continue;
}
b[0][d] = 1;
} else if (a[i] == -1) d -- ;
else if (a[i] == 2) {
d ++ ;
if (b[1][d] == 1) {
flag = 1;
b[0][d] = 0;
continue;
}
b[1][d] = 1;
} else if (a[i] == -2) d -- ;
}
if (flag == 1) cout << "No" << endl;
else cout << "YES" << endl;
}
signed main() {
int _;
cin >> _;
while (_ -- ) solve();
return 0;
}
詳細信息
Test #1:
score: 0
Wrong Answer
time: 1ms
memory: 5820kb
input:
6 )) ((() [()] ()[()]() ([()]) ([])([])
output:
YES No YES No No No
result:
wrong answer expected YES, found NO [5th token]