Submission #524491

#TimeUsernameProblemLanguageResultExecution timeMemory
524491PetyBeautiful row (IZhO12_beauty)C++14
100 / 100
503 ms205424 KiB
#include <bits/stdc++.h>
#define ll long long

using namespace std;

const int INF = 1e9;
const int MOD = 1e9 + 7;

int n, v[20], ok[20][20];
short bits[(1 << 20)][20];
long long dp[(1 << 20)][20];

int base2 (int x) {
  int cnt = 0;
  while (x) {
    if (x % 2 == 1)
      cnt++;
    x /= 2;
  }
  return cnt;
}

int base3 (int x) {
  int cnt = 0;
  while (x) {
    if (x % 3 == 1)
      cnt++;
    x /= 3;
  }

  return cnt;
}


int main () 
{
  ios_base::sync_with_stdio(false);
  cin.tie(0); cout.tie(0);
  cin >> n;
  for (int i = 0; i < n; i++) {
    cin >> v[i];
  }
  for (int i = 0; i < n; i++) 
    for (int j = 0; j < n; j++)
      if (base2(v[i]) == base2(v[j]) || base3(v[i]) == base3(v[j]))
        ok[i][j] = 1;
  for (int i = 1; i < (1 << n); i++) {
    for (int j = 0; j < n; j++)
      if (i & (1 << j))
        bits[i][++bits[i][0]] = j;
  }
  for (int i = 1; i < (1 << n); i++) {
    if (bits[i][0] == 1) {
      dp[i][bits[i][1]] = 1;
      continue;
    }
    for (int j = 1; j <= bits[i][0]; j++)
      for (int k = 1; k <= bits[i][0]; k++)
        if (j != k) {
          int b1 = bits[i][j];
          int b2 = bits[i][k];
          if (ok[b1][b2])
          dp[i][b1] = (dp[i ^ (1 << b1)][b2] + dp[i][b1]);
        }
  }
  long long ans = 0;
  for (int i = 0; i < n; i++)
    ans += dp[(1 << n) - 1][i];  
  cout << ans;
  return 0;
}

#Verdict Execution timeMemoryGrader output
Fetching results...