#include using namespace std; #define rep(i, n) for (int i = 0; i < (n); ++i) using ll = long long; using ull = unsigned long long; int main() { cin.tie(nullptr)->sync_with_stdio(false); int n; cin >> n; vector a(n); rep(i, n) cin >> a[i]; vector cnt(3, 0); ll ans = 0; rep(i, n) { if (a[i] == 1) { ans += 2 * cnt[0]; ans += 3 * cnt[1]; ans += 2 * cnt[2]; cnt[0]++; } else if (a[i] == 2) { ans += 3 * cnt[0]; ans += 1 * cnt[1]; ans += 1 * cnt[2]; cnt[1]++; } else { ans += 2 * cnt[0]; ans += 1 * cnt[1]; ans += 1 * cnt[2]; cnt[2]++; } } cout << ans << '\n'; return 0; }