# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
427006 | Mazaalai | Paint By Numbers (IOI16_paint) | C++14 | 1 ms | 204 KiB |
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>
using namespace std;
string solve_puzzle(string s, vector<int> c1) {
int n = s.size(), k = c1.size();
vector <int> c(k+5, 0);
for (int i = 1; i <= k; i++) c[i] = c1[i-1];
string ans = "";
for (int i = 0; i < n; i++) ans += '?';
vector <int> pre(k+5, 1), suf(k + 5, n);
pre[1] = 1, suf[k] = n;
for (int i = 2; i <= k; i++) pre[i] = pre[i-1] + c[i-1]+1;
for (int i = k - 1; i > 0; i--) suf[i] = suf[i+1] - c[i+1] - 1;
for (int i = 1; i <= k; i++) {
// cout << i << ": " << pre[i] << ' ' << suf[i] << '\n';
int len = suf[i] - pre[i] + 1;
if (len >= c[i] * 2) continue;
int len1 = c[i] * 2 - len;
for (int j = 0; j < len1; j++) {
int st =
ans[j + k - len1 + pre[i]] = 'X';
}
}
return ans;
}
Compilation message (stderr)
# | 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... |