Submission #964904

#TimeUsernameProblemLanguageResultExecution timeMemory
964904codefoxRegions (IOI09_regions)C++14
90 / 100
7399 ms131072 KiB
#include<bits/stdc++.h> using namespace std; #pragma GCC optimize("Ofast") #pragma GCC target("avx,avx2,fma") #define pii pair<int, short> const int K = 100; const int N = 200000; const int R = 25000; vector<int> graph[N]; short region[N]; vector<int> rind; int start[N]; int ende[N]; int c =0 ; vector<vector<int>> dpback; int backsolutions[R][K]; int frontsolutions[K][R]; void dfsback(int i) { start[i] = c++; for (int ele:graph[i]) { dfsback(ele); for (int j = 0; j < K; j++) { dpback[i][j] += dpback[ele][j]; } } for (int j = 0; j < K; j++) { backsolutions[region[i]][j] += dpback[i][j]; } if (rind[region[i]]!= -1) dpback[i][rind[region[i]]]++; ende[i] = c; } void dfsfront(int i, vector<int> dpfront) { for (int j = 0; j < K; j++) { frontsolutions[j][region[i]] += dpfront[j]; } if (rind[region[i]]!=-1) dpfront[rind[region[i]]]++; for (int ele:graph[i]) { dfsfront(ele, dpfront); } } int main() { //freopen("input.txt", "r", stdin); //freopen("output.txt", "w", stdout); ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); int n, r, q; cin >> n >> r >> q; rind.assign(r, -1); for (int i = 0; i < R*K; i++) { backsolutions[0][i] = 0; frontsolutions[0][i] = 0; } vector<vector<int>> part(r); cin >> region[0]; region[0]--; part[region[0]].push_back(0); for (int i = 1; i < n; i++) { int b; cin >> b; graph[b-1].push_back(i); cin >> region[i]; region[i]--; part[region[i]].push_back(i); } vector<int> rsum(r, 0); int d =0; for (int i = 0; i < n; i++) rsum[region[i]]++; for (int i = 0; i < r; i++) { if (rsum[i]*K > N) { rind[i] = d++; } } rsum.clear(); dpback.assign(n, vector<int>(K, 0)); dfsback(0); dpback.clear(); dfsfront(0, vector<int>(K, 0)); vector<pii> s; while (q--) { int a, b; cin >> a >> b; a--; b--; if (rind[a]!=-1) cout << frontsolutions[rind[a]][b] << endl; else if (rind[b]!=-1) cout << backsolutions[a][rind[b]] << endl; else { for (int ele:part[a]) { s.push_back({start[ele], 2}); s.push_back({ende[ele], 0}); } for (int ele:part[b]) { s.push_back({start[ele], 1}); } sort(s.begin(), s.end()); int open = 0; int sol = 0; for (pii ele:s) { if (ele.second == 0) open--; if (ele.second == 1) sol += open; if (ele.second == 2) open++; } cout << sol << endl; s.clear(); } } return 0; }

Compilation message (stderr)

regions.cpp: In function 'int main()':
regions.cpp:75:29: warning: iteration 100 invokes undefined behavior [-Waggressive-loop-optimizations]
   75 |         backsolutions[0][i] = 0;
      |         ~~~~~~~~~~~~~~~~~~~~^~~
regions.cpp:73:23: note: within this loop
   73 |     for (int i = 0; i < R*K; i++)
      |                     ~~^~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...