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>
#define int long long
using namespace std;
vector<int> bt;
bool backtrack(string &s, vector<signed> &c, int i, int p){
int n = s.size(); int k = c.size();
if(i == k) return true;
bool exist = false;
do{
bool okay = true; int mine;
for(int j = p; j < p + c[i]; j ++){
if(s[j] == '_'){ okay = false; mine = j; break; }
if(s[j] == 'X'){ exist = true; }
}
if(okay && (p + c[i] == n || s[p + c[i]] != 'X')){
bt.push_back(p);
if(backtrack(s,c,i+1,p + c[i] + 1)) return true;
bt.pop_back();
}
else p = mine + 1;
}while(p + c[i] <= n && !exist);
return false;
}
string solve_puzzle(string s, vector<signed> c) {
int n = s.size(), k = c.size();
string ans = s;
//put all to the lefts
backtrack(s,c,0,0);
vector<int> l = bt;
//put all to the rights
bt.clear();
reverse(s.begin(), s.end());
reverse(c.begin(), c.end());
backtrack(s,c,0,0);
reverse(s.begin(), s.end());
reverse(c.begin(), c.end());
reverse(bt.begin(), bt.end());
for(int i = 0; i < k; i ++) bt[i] = n-bt[i]-c[i];
vector<int> r = bt;
//apply x's
for(int i = 0; i < k; i ++){
for(int j = l[i]; j < r[i] + c[i]; j ++) ans[j] = (ans[j] == '.' ? '?' : ans[j]);
for(int j = r[i]; j < l[i] + c[i]; j ++) ans[j] = 'X';
}
for(char &v : ans) if(v == '.') v = '_';
return ans;
}
Compilation message (stderr)
paint.cpp: In function 'bool backtrack(std::string&, std::vector<int>&, long long int, long long int)':
paint.cpp:23:23: warning: 'mine' may be used uninitialized in this function [-Wmaybe-uninitialized]
23 | else p = mine + 1;
| ~~~~~^~~
# | 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... |