Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 17713 | Accepted: 10660 |
Description
S (((()()()))) P-sequence 4 5 6666 W-sequence 1 1 1456
Input
Output
Sample Input
2 6 4 5 6 6 6 6 9 4 6 6 6 6 8 9 9 9
Sample Output
1 1 1 4 5 6 1 1 2 4 5 1 1 3 9
题意: 给出字符串的表达式P, 得到另一种表达式W
表达式P的规则是这样的: P1, P2, Pi...Pn, Pi表示的是, 第i个右括号左边有Pi个左括号
表达式W的规则是这样的: W1, W2, Wi...Wn, Wi表示的是, 第i个右括号与其对应的左括号形成的一对括号中, 有几对括号, 包括自己本身;
做法: 由P规则得出字符串, 再由该字符串从左至右逐个找右括号, 一对一对查, 查一对, 标记成"##", 以便下次查的时候不会重复, 以及可以得知这里已有一对括号, 便于统计
AC代码:
#include
int main() {
int t;
scanf("%d", &t);
while(t--) {
char str[50];
int ans[50];
int n, formal, now;
scanf("%d", &n);
n--;
scanf("%d", &formal);
int i, pos;
for(pos = 0; pos < formal; pos++)
str[pos] = '(';
str[pos] = ')';
while(n--) {
scanf("%d", &now);
int num;
num = now - formal + pos + 1;
for(i = pos+1; i < num; i++)
str[i] = '(';
str[i] = ')';
pos = i;
formal = now;
}
int count;
int tpos = 0;
for(i = 0 ; i <= pos; i++) {
count = 0;
if(str[i] == ')') {
for(int j = i-1; j >= 0; j--) {
if(str[j] == '#')
count++;
if(str[j] == '(') {
str[j] = '#';
str[i] = '#';
break;
}
}
ans[tpos++] = (count / 2) + 1;
}
}
for(int i = 0; i < tpos; i++) {
if(i != tpos-1)
printf("%d ", ans[i]);
else
printf("%d\n", ans[i]);
}
}
return 0;
}