# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
61942 | khsoo01 | parentrises (BOI18_parentrises) | C++11 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
const int N = 2000005;
int n;
char a[N], b[N];
void solve1 () {
scanf("%s",a+1);
n = strlen(a+1);
queue<int> X, Y, Q;
int A = 0, B = 0, C = 0, D = 0;
for(int i=1;i<=n;i++) {
if(a[i] == '(') {
if(D < C) {
D++;
B++;
b[i] = 'R';
Y.push(i);
}
else {
C++;
A++;
b[i] = 'B';
X.push(i);
}
}
else {
A--;
B--;
b[i] = 'G';
Q.push(i);
}
while(A < 0 && !Y.empty()) {
int T = Y.front();
Y.pop();
b[T] = 'G';
A++;
}
while(B < 0 && !X.empty()) {
int T = X.front();
X.pop();
b[T] = 'G';
B++;
}
while(A < 0 && !Q.empty()) {
int T = Q.front();
Q.pop();
b[T] = 'R';
A++;
}
while(B < 0 && !Q.empty()) {
int T = Q.front();
Q.pop();
b[T] = 'B';
B++;
}
if(A < 0 || B < 0) {
puts("impossible");
return;
}
}
if(A > 0 || B > 0) {
puts("impossible");
return;
}
b[n+1] = 0;
printf("%s\n",b+1);
}
const int M = 301, mod = 1e9+7;
int dt[M][M][2*M];
void calc () {
dt[0][0][0][0] = 1;
for(int i=1;i<M;i++) for(int j=0;j<i;j++) for(int k=0;k<i;k++) {
if(k >= 2) {
dt[i][j+1][k-2] = (dt[i][j+1][k-2] + dt[i-1][j][k]) % mod;
}
else if(j+k >= 1) {
dt[i][j+k-1][0] = (dt[i][j+k-1][0] + dt[i-1][j][k]) % mod;
}
dt[i][j+1][k+1] = (dt[i][j+1][k+1] + dt[i-1][j][k]) % mod;
}
}
void solve2() {
int T, R = 0;
scanf("%d",&T);
for(int i=0;i<M;i++) {
R = (R + dt[T][i][0]) % mod;
}
printf("%d\n",R);
}
int main()
{
int typ, tc;
scanf("%d%d",&typ,&tc);
if(typ == 2) calc();
while(tc--) {
if(typ == 1) solve1();
else solve2();
}
}