Submission #619912

#TimeUsernameProblemLanguageResultExecution timeMemory
619912cfalasPaint By Numbers (IOI16_paint)C++17
0 / 100
1 ms212 KiB
#include "paint.h" #include<bits/stdc++.h> using namespace std; #define mp make_pair #define INF 10000000 #define MOD 1000000007 #define MID ((l+r)/2) #define HASHMOD 2305843009213693951 #define ll long long #define ull unsigned long long #define F first #define S second typedef pair<ll, ll> ii; typedef pair<ii, int> iii; typedef vector<int> vi; typedef vector<ii> vii; typedef map<int, int> mii; #define EPS 1e-6 #define FOR(i,n) for(int i=0;i<((int)(n));i++) #define FORi(i,a,b) for(int i=((int)(a));i<((int)(b));i++) #define FOA(v, a) for(auto v : a) #define len(x) ((int)x.size()) string solve_puzzle(string s, vector<int> c) { int n = len(s); int k = len(c); string dp[k+1][n]; FOR(i,n) cout<<setw(n+2)<<i; cout<<endl; FOR(i,n){ FOR(j,n) dp[0][i]+='Z'; FOR(j,n) if(s[j]!='.') dp[0][i][j]=s[j]; /* bool ok = true; if(i>=c[0]-1){ FORi(j, i-c[0]+1, i+1){ if(dp[0][i][j]!='Z' && dp[0][i][j]!='X') ok=false; else dp[0][i][j] = 'X'; } } else ok = false; if(!ok) dp[0][i] = ""; //FOR(j,len(dp[0][i])) if(dp[0][i][j]=='Z') dp[0][i][j]='_';*/ cout<<setw(n+2)<<dp[0][i]; } cout<<endl; FORi(i,1,k+1){ FOR(j,n){ dp[i][j] = ""; bool ok = true; if(j>c[i-1]) FORi(k, j-c[i-1]+1, j+1) if(s[i]!='.' && s[i]!='X') ok = false; if(j>c[i-1] && s[j-c[i-1]]=='X') ok = false; if(j>c[i-1] && !dp[i-1][j-c[i-1]-1].empty() && ok){ FOR(k,j+1) dp[i][j]+="Z"; FOR(k,c[i-1]) dp[i][j][j-k] = 'X'; dp[i][j][j-c[i-1]] = '_'; FOR(k,n-j-1) dp[i][j]+='_'; FOR(k,j-1){ if(k+1+c[i-1]>j) continue; if(dp[i-1][k].empty()) continue; FOR(m, j-c[i-1]){ if(dp[i][j][m]=='Z') dp[i][j][m] = dp[i-1][k][m]; else if(dp[i-1][k][m]!=dp[i][j][m]) dp[i][j][m] = '?'; } } } cout<<setw(n+2)<<dp[i][j]; } cout<<endl; } string ans = dp[k][n-1]; FOR(z,n){ if(dp[k][z].empty()) continue; FOR(m, n){ if(dp[k][z][m]!=ans[m]) ans[m] = '?'; //else cout<<m; } //cout<<setw(j+3)<<dp[i][j]; } FOR(i,n) if(ans[i]=='Z') ans[i]='_'; return ans; }

Compilation message (stderr)

paint.cpp: In function 'std::string solve_puzzle(std::string, std::vector<int>)':
paint.cpp:20:18: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
   20 | #define FOR(i,n) for(int i=0;i<((int)(n));i++)
      |                  ^~~
paint.cpp:30:2: note: in expansion of macro 'FOR'
   30 |  FOR(i,n) cout<<setw(n+2)<<i; cout<<endl;
      |  ^~~
paint.cpp:30:31: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
   30 |  FOR(i,n) cout<<setw(n+2)<<i; cout<<endl;
      |                               ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...