//#include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; //using namespace atcoder; //* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *// void input() { } void solve() { long long N; cin >> N; long long A1 = 0, A2 = 0, A3 = 0; for(int i = 0; i < N; i++) { int A; cin >> A; if(A == 1) A1++; else if(A == 2) A2++; else A3++; } long long ans = 0; long long tmp = 0; tmp += A1 * A2 * 2; tmp += A1 * A1; tmp += A1 * A3 * 2; ans += A1 * A2 * 2 * 3; ans += A1 * A1 * 2; ans += A1 * A3 * 2 * 2; ans += (N * N - tmp) * 1; ans -= A1 * 2; ans -= (N - A1) * 1; ans /= 2; cout << ans << endl; } //* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *// int main() { std::ifstream in("input.txt"); std::cin.rdbuf(in.rdbuf()); std::cin.tie(0); ios::sync_with_stdio(false); input(); solve(); return 0; }