Submission #473627

#TimeUsernameProblemLanguageResultExecution timeMemory
473627OttoTheDinoFish (IOI08_fish)C++17
0 / 100
228 ms25568 KiB
#include <bits/stdc++.h> using namespace std; #define rep(i,s,e) for (ll i = s; i <= e; ++i) #define pb push_back #define fi first #define se second #define all(a) a.begin(), a.end() typedef long long ll; typedef pair<ll, ll> ii; typedef vector<ii> vii; const ll mx = 5e5+5; set<ll> st; ll nums[mx] = {}; ll add_cnt (ll cnt) { if (cnt && --nums[cnt]==0) st.erase(cnt); if (++nums[++cnt]==1) st.insert(cnt); return cnt; } int main() { ios::sync_with_stdio(0); cin.tie(0); ll f, k, m, ans = 0; cin >> f >> k >> m; vii bois; rep (i,0,f-1) { ll l, tp; cin >> l >> tp; bois.pb({l, tp}); } sort(all(bois)); ll last[mx], id = 0, org_cnt[mx] = {}, cnt[mx] = {}, init = 1; rep (i,0,f-1) last[bois[i].se] = i; while (bois.back().fi >= 2*bois[id].fi) { org_cnt[bois[id].se]=add_cnt(org_cnt[bois[id].se]); id++; } org_cnt[bois.back().se]=add_cnt(org_cnt[bois.back().se]); for (ll el : st) init = init*(el+1)%m*nums[el]%m; st.clear(); memset(nums, 0, 8*mx); id = 0; rep (i,0,f-1) { if (i==last[bois[i].se]) { while (bois[i].fi >= 2*bois[id].fi) { cnt[bois[id].se]=add_cnt(cnt[bois[id].se]); id++; } if (cnt[bois[i].se]==org_cnt[bois[i].se]) { ll res = 1; for (ll el : st) { if (el==cnt[bois[i].se]) { if (nums[el]==1) continue; res = res*(el+1)%m*(nums[el]-1)%m; } else res = res*(el+1)%m*nums[el]%m; } ans = (ans+res)%m; } } } cout << (init+ans+m-1)%m << "\n"; 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...
#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...
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...