This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "paint.h"
#include <bits/stdc++.h>
#include <cstdlib>
using namespace std;
#define FOR(i, a, b) for (int i = (a); i <= (b); i++)
#define REP(n) FOR(O, 1, (n))
#define f first
#define s second
#define pb push_back
typedef vector<int> vi;
typedef pair<int, int> pii;
typedef vector<pii> vii;
int fr[110], to[110];
std::string solve_puzzle(std::string s, std::vector<int> c) {
string ret = s;
int n = (int)s.size();
int k = (int)c.size();
int sum = 0;
FOR(i, 0, k-1) sum += c[i];
if (sum + k-1 == n) {
int cur = 0;
FOR(i, 0, k-1) {
REP(c[i]) {
ret[cur] = 'X';
cur++;
}
if (i < k-1) ret[cur] = '_';
cur++;
}
return ret;
}
int cur = -1;
FOR(i, 0, k-1) {
cur += c[i];
to[i] = cur;
cur++;
}
cur = n;
for (int i = k-1; i >= 0; i--) {
cur -= c[i];
fr[i] = cur;
cur--;
}
FOR(i, 0, n-1) ret[i] = '?';
FOR(i, 0, k-1) FOR(j, fr[i], to[i])
ret[j] = 'X';
// FOR(i, 0, k-1) cout << " i = " << i << " fr = " << fr[i] << " to = " << to[i] << endl;
return ret;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |