Submission #937768

#TimeUsernameProblemLanguageResultExecution timeMemory
937768wojciech_domin2Lamps (JOI19_lamps)C++14
100 / 100
596 ms36140 KiB
#include <bits/stdc++.h> #define pb push_back #define ins insert #define fi first #define se second #define debug(x) cout<<#x<<" = "<<x<<"\n"; using namespace std; using ll = long long; using ld = long double; template <typename H, typename T> ostream& operator<<(ostream& os, pair<H, T> m){ return os <<"("<< m.fi<<", "<<m.se<<")"; } template <typename H> ostream& operator<<(ostream& os, vector<H> V){ os<<"{"; for(int i=0; i<V.size(); i++){ if(i)os<<" "; os<<V[i]; } os<<"}"; return os; } const int MAX_N = 1000020; const int INF = 21372137; char A[MAX_N]; char B[MAX_N]; int dp[MAX_N][2][4]; bitset<MAX_N> a,b; int main(){ ios_base::sync_with_stdio(false); cin.tie(0); int N; cin>>N; for(int i = 1; i <= N; i++){ cin>>A[i]; } for(int i = 1; i <= N; i++){ cin>>B[i]; } for(int i =1; i <= N; i++){ a[i] = int(A[i]^'0'); b[i] = int(B[i]^'0'); } for(int j = 0; j < MAX_N; j++){ for(int i = 0; i < 4; i++){ dp[j][0][i] = INF; dp[j][1][i] = INF; } } dp[0][0][0] = 0; for(int i = 1; i <= N; i++){ for(int k = 0; k < 2; k++){ for(int j = 0; j < 4; j++){ vector<pair<int,int> > cennik; cennik.pb({0,0}); cennik.pb({1,1}); cennik.pb({2,1}); cennik.pb({j,0}); for(auto t : cennik){ dp[i][k][t.fi] = min(dp[i-1][0][j] + k + t.se, dp[i][k][t.fi]); dp[i][k][t.fi] = min(dp[i-1][1][j] + 0 + t.se, dp[i][k][t.fi]); } } } for(int k = 0; k < 2; k++){ for(int j = 0; j < 4; j++){ int kwiatek = j; int wart_a = int(A[i]^'0'); int wart_b = int(B[i]^'0'); bool ok = false; if(kwiatek == 0){ if((wart_a^k)==wart_b) ok = true; }else{ kwiatek--; kwiatek^=k; if(wart_b == kwiatek) ok = true; } if(!ok){ dp[i][k][j] = INF; } } } } int odp = INF; for(int i = 0; i < 4; i++){ odp = min(odp,dp[N][0][i]); odp = min(odp,dp[N][1][i]); } cout<<odp<<"\n"; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...