# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
116439 | Meloric | Paint By Numbers (IOI16_paint) | C++14 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "paint.h"
#include <iostream>
#include <cstdlib>
#define pb push_back
#define pii pair<int, int>
#define X first
#define Y second
using namespace std;
vector<vector<vector<int>>> dp;
vector<pii> ans;
vector<vector<int> vis;
void color(int n, int k, vector<int>&c){
if(n < 0)return;
if(vis[n][k])return;
vis[n][k] = 1;
if(dp[n][k][0]){
ans[n].X = 1;
color(n-1, k, c);
}
if(dp[n][k][1]){
color(n-c[k-1]-1, k-1, c);
ans[n-c[k-1]].X=1;
ans[n-c[k-1]].Y++;
ans[n].Y--;
}
}
string solve_puzzle(string s, vector<int> c) {
vector<int> bla, whi;
int n = s.size();
bla.pb(0); whi.pb(0);
ans.assign(n+1, {0, 0});
for(auto i : s){
if(i == '_'){
whi.pb(whi.back()+1);
continue;
}
if(i == 'X'){
bla.pb(bla.back()+1);
continue;
}
bla.pb(bla.back());
whi.pb(whi.back());
}
int k = c.size();
dp.assign(n+1, vector<vector<int>>(k+1, vector<int>(2)));
vis.assign(n+1, vector<int>(k+1));
dp[0][0][0] = 1;
for(int i = 0; i< s.size(); i++){
if(s[i] == 'X')break;
dp[i+1][0][0] = 1;
}
for(int i = 0; i < s.size(); i++){
for(int j = 0; j < k; j++){
if(s[i] != 'X'){
dp[i+1][j+1][0] = max(dp[i][j+1][0], dp[i][j+1][1]);
}
if(s[i] != '_'){
if(i+1-c[j]>=0){
if(whi[i+1]- whi[i+1-c[j]] == 0){
dp[i+1][j+1][1] = dp[i+1-c[j]][j][0];
}
}
}
}
}
/*
for(auto i : dp){
for(auto j : i){
cout << j[0]<<' '<<j[1]<<'|';
}
cout << '\n';
}*/
color(n, k, c);
string ret;
for(int i = 1; i < ans.size(); i++){
if(ans[i].X > 0 && ans[i-1].Y>0){
ret.pb('?');
ans[i].Y+=ans[i-1].Y;
continue;
}
if(ans[i].X > 0){
ret.pb('_');
ans[i].Y+=ans[i-1].Y;
continue;
}
ret.pb('X');
ans[i].Y+=ans[i-1].Y;
}
//return "?????????????";
return ret;
//return "";
}