QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#511252 | #8776. Not Another Constructive! | Noobie_99# | WA | 141ms | 329676kb | C++20 | 1.7kb | 2024-08-09 18:03:14 | 2024-08-09 18:03:14 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define tsolve int t; cin >> t; while(t--) solve
#define debug(x) cerr << __LINE__ << ": "#x" = " << (x) << endl
#define all(x) ::begin(x), ::end(x)
#define sz(x) (int)::size(x)
using ll = long long;
using ld = long double;
constexpr int N1 = 40 + 1;
constexpr int N2 = 20*20 + 1;
constexpr int N3 = 2500 + 1;
bool dp[N1][N2][N3];
bool dp2[N1][N2][N3];
char pre[N1][N1][N2][N3];
void solve() {
int n, K;
cin >> n >> K;
string s;
cin >> s;
dp[0][0][0] = true;
for (int i=0; i<n; i++) {
memset(dp2, false, sizeof(dp2));
int n1 = i;
int n2 = min(N2-1, (i+1)/2*(i/2));
int n3 = min(N3-1, (i+2)/3 * (i+2)/3 * (i/3));
for (int j=0; j<=n1; j++) {
for (int k=0; k<=n2; k++) {
for (int l=0; l<=n3; l++) if (dp[j][k][l]) {
if (s[i] == 'N' || s[i] == '?') {
pre[i+1][j+1][k][l] = 'N';
dp2[j+1][k][l] = true;
}
if (s[i] == 'A' || s[i] == '?') {
pre[i+1][j][k+j][l] = 'A';
dp2[j][k+j][l] = true;
}
if (s[i] == 'C' || s[i] == '?') {
pre[i+1][j][k][l+k] = 'C';
dp2[j][k][l+k] = true;
}
if (s[i] != 'N' && s[i] != 'A' && s[i] != 'C') {
pre[i+1][j][k][l] = s[i];
dp2[j][k][l] = true;
}
}
}
}
memcpy(dp, dp2, sizeof(dp));
}
int x = -1, y = -1, z = -1;
for (int i=0; i<N1; i++) for (int j=0; j<N2; j++) if (dp[i][j][K]) {
x = i, y = j, z = K;
}
if (x == -1) {
cout << "-1\n";
return;
}
for (int i=n; i>0; i--) {
s[i-1] = pre[i][x][y][z];
if (s[i-1] == 'N') x--;
else if (s[i-1] == 'A') y -= x;
else if (s[i-1] == 'C') z -= y;
}
cout << s << '\n';
}
int main() {
cin.tie(0)->sync_with_stdio(false);
cout << setprecision(16);
solve();
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 0
Wrong Answer
time: 141ms
memory: 329676kb
input:
22 2 N??A??????C???????????
output:
NN?ANNNNNNCNNNNNNNNNNN
result:
wrong answer illegal char