Submission #472958

#TimeUsernameProblemLanguageResultExecution timeMemory
472958MohamedFaresNebiliRegions (IOI09_regions)C++14
Compilation error
0 ms0 KiB
#pragma comment(linker, "/stack:200000000") #pragma GCC optimize("Ofast, unroll-loops", "omit-frame-pointer","inline") #pragma GCC option("arch=native","tune=native","no-zero-upper") #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native,avx2") #include <bits/stdc++.h> using namespace std; using ll = long long; using ld = long double; using ii = pair<int, int>; using vl = vector<long long>; #define mp make_pair #define pb push_back #define pp pop_back #define ff first #define ss second #define lb lower_bound #define ub upper_bound #define all(x) (x).begin() , (x).end() const int N = 2*100005; const long long MOD = 1e9+7; const long double EPS = 0.000000001; const double PI = 3.14159265358979323846; const int nx[4]={1, -1, 0, 0}, ny[4]={0, 0, 1, -1}; long long gcd(int a, int b) { return (b==0?a:gcd(b, a%b)); } long long lcm(int a, int b) { return a*(b/gcd(a, b)); } long long fact(int a) { return (a==1?1:a*fact(a-1)); } int n, r, q, timer=0, arr[200005], tin[200005], out[200005]; vector<int>adj[200005], se[25005]; vector<int>home[25005]; map<ii, int>dp; void dfs(int v, int p) { tin[v]=++timer; se[arr[v]].pb(timer); for(auto u:adj[v]) { if(u==p) continue; dfs(u, v); } out[v]=++timer; } int32_t main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); scanf("%d%d%d", &n, &r, &q); scanf("%d", &arr[1]); home[arr[1]].pb(1); for(int l=2;l<=n;l++) { int a, h; scanf("%d%d", &a, &h); home[h].pb(l); adj[a].pb(l); adj[l].pb(a); arr[l]=h; } dfs(1, 1); while(q--) { int a, b; scanf("%d%d", &a, &b); int res=0; if(dp.find({a, b})!=dp.end()) { cout<<dp[{a, b}]<<"\n"<<flush; continue; } for(auto u:home[a]) { int l=tin[u], r=out[u]; int add=lb(all(se[b]), r)-lb(all(se[b]), l); res+=add; } dp[{a, b}]=res; cout<<res<<"\n"<<flush; } return 0; }

Compilation message (stderr)

regions.cpp:1: warning: ignoring '#pragma comment ' [-Wunknown-pragmas]
    1 | #pragma comment(linker, "/stack:200000000")
      | 
regions.cpp:3: warning: ignoring '#pragma GCC option' [-Wunknown-pragmas]
    3 | #pragma GCC option("arch=native","tune=native","no-zero-upper")
      | 
regions.cpp:2:74: warning: bad option '-f unroll-loops' to pragma 'optimize' [-Wpragmas]
    2 | #pragma GCC optimize("Ofast, unroll-loops", "omit-frame-pointer","inline")
      |                                                                          ^
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
    4 | #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native,avx2")
      |                                                                                  ^
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attribute 'optimize' [-Wattributes]
regions.cpp:4:82: warning: bad option '-f unroll-loops' to attr