Submission #598660

#TimeUsernameProblemLanguageResultExecution timeMemory
598660Valaki2Amusement Park (CEOI19_amusementpark)C++14
19 / 100
78 ms10116 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long

const int mod = 998244353;

int n, m;
vector<int> a;
vector<int> b;
unordered_set<int> s;

void solve() {
    cin >> n >> m;
    a.assign(m, 0);
    b.assign(m, 0);
    for(int i = 0; i < m; i++) {
        cin >> a[i] >> b[i];
        a[i]--;
        b[i]--;
    }
    vector<int> v(n, 0);
    for(int i = 0; i < n; i++) {
        v[i] = i;
    }
    do {
        int c = 0;
        for(int i = 0; i < m; i++) {
            c |= (v[a[i]] > v[b[i]]) * (1 << i);
        }
        s.insert(c);
    } while(next_permutation(v.begin(), v.end()));
    int ans = 0;
    for(int x : s) {
        ans = ans + __builtin_popcountll(x);
    }
    ans %= mod;
    cout << ans << "\n";
}

signed main() {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    solve();
    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...
#Verdict Execution timeMemoryGrader output
Fetching results...