Submission #708589

#TimeUsernameProblemLanguageResultExecution timeMemory
708589MatjazBeautiful row (IZhO12_beauty)C++14
100 / 100
2705 ms164528 KiB
#include<vector> #include<iostream> #include <stdlib.h> #include <algorithm> #include <stack> #include <string.h> using namespace std; long long dp[1<<20][20]; int N; vector<int> a; int onesdp[20][4]; int ones(int x, int base){ if (onesdp[x][base] != -1) return onesdp[x][base]; int ans = 0; int tmp = a[x]; while (tmp > 0){ if (tmp % base == 1) ans++; tmp /= base; } return onesdp[x][base] = ans; } bool works(int a, int b){ return ones(a, 2) == ones(b,2) || ones(a, 3) == ones(b, 3); } long long ways(int S, int last){ if (dp[S][last] != -1) return dp[S][last]; if (S == (1<<N) - 1) return 1; long long ans = 0; for (int i=0;i<N;i++){ if ((S & (1<<i)) != 0) continue; if (works(last, i)) ans += ways(S + (1<<i), i); } return dp[S][last] = ans; } int main(){ memset(dp, -1, sizeof(dp)); memset(onesdp, -1, sizeof(onesdp)); cin >> N; a.assign(N, 0); for (int i=0;i<N;i++) cin >> a[i]; long long total = 0; for (int i=0;i<N;i++) total += ways(1<<i, i); cout << total << endl; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...