이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "paint.h"
#include<bits/stdc++.h>
using namespace std;
std::string solve_puzzle(std::string s, std::vector<int> c) {
long long n = (int)s.length();
long long k = (int)c.size();
vector<long long>pref(n + 1,0),pref2(n + 1,0);
for (int i = 0;i<n;++i){
pref[i + 1] = pref[i] + (s[i] == '_');
pref2[i + 1] = pref2[i] + (s[i] =='X');
}
vector<vector<vector<long long>>>dp(n + 1,vector<vector<long long>>(k + 1,vector<long long>(2,0))),came(n + 1,vector<vector<long long>>(k + 1,vector<long long>(2,0)));
function<long long(long long,long long,long long)>solve = [&](long long u,long long v,bool ok){
if (u == n){
if (v != k)return dp[u][v][ok] = 0;
return dp[u][v][ok] = 1;
}
if (came[u][v][ok])return dp[u][v][ok];
came[u][v][ok] = true;
if (v == k){
if (pref2[n] - pref2[u])return dp[u][v][ok] = 0;
return dp[u][v][ok] = solve(u + 1,v,0);
}
long long ans = 0 ;
if (u + c[v]<= n && !ok && !(pref[u + c[v]] - pref[u]) && !(u + c[v] < n && s[u + c[v]] == 'X')){
ans += solve(u + c[v],v + 1,1);
}
else if (s[v] == 'X'){
return dp[u][v][ok] = 0;
}
if (s[v]!='X'){
ans +=solve(u + 1,v,0);
}
return dp[u][v][ok] = ans;
};
solve(0,0,0);
string answer = s;
for (long long i = 0;i<n;++i){
if (answer[i] == '.')answer[i] = '?';
}
vector<long long>all(n,0);
for (long long i = 1;i<=k;++i){
vector<long long>ans(n,0);
long long total = 0;
for (long long j = 0;j<=n;++j){
if (j - c[i - 1] >= 0){
for (long long p = 1;p<=c[i - 1];++p){
ans[j - p]+=dp[j][i][1];
all[j - p]+=dp[j][i][1];
}
}
total+=dp[j][i][1];
}
for (long long j = 0;j<n;++j){
if (ans[j] == total)answer[j] = 'X';
}
}
for (long long i = 0;i<n;++i){
if (all[i] == 0){
answer[i] = '_';
}
else if (all[i] == dp[0][0][0]){
answer[i] = 'X';
}
}
return answer;
}
| # | 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... |