Submission #1039234

#TimeUsernameProblemLanguageResultExecution timeMemory
1039234vnm06Werewolf (IOI18_werewolf)C++14
0 / 100
4051 ms144108 KiB
#include<bits/stdc++.h> #include "werewolf.h" using namespace std; int n, m, q; int fenw[400005]; void update(int pos) { while(pos<=n) { fenw[pos]++; pos+=(pos&(-pos)); } } int query(int pos) { int res=0; while(pos) { res+=fenw[pos]; pos-=(pos&(-pos)); } return res; } int query(int le, int ri) { return query(ri)-query(le-1); } int brcomp=0; vector<int> compn[400005], gr[400005]; int nom_comp[400005], par[400005], par_comp[400005]; int new_nom[400005], tek_nom=1; int be_id[400005], en_id[400005]; vector<int> spis[400005]; void dfs(int v, bool fl) { if(fl) { new_nom[v]=tek_nom; be_id[v]=tek_nom; tek_nom++; } int brs=spis[v].size(); for(int i=0; i<brs; i++) { dfs(spis[v][i], fl); } if(fl) en_id[v]=tek_nom-1; } vector<int> spis_1[400005], spis_2[400005]; int tree_1[20][400005], tree_2[20][400005]; void build_tree_1() { for(int j=n-1; j>=0; j--) tree_1[0][j]=par[j]; for(int j=n-1; j>=0; j--) spis_1[par[j]].push_back(j); for(int lvl=1; lvl<20; lvl++) { for(int v=0; v<n; v++) { if(tree_1[lvl-1][v]==-1) tree_1[lvl][v]=-1; else tree_1[lvl][v]=tree_1[lvl-1][tree_1[lvl-1][v]]; } } } void build_tree_2() { for(int j=n-1; j>=0; j--) tree_2[0][j]=par[j]; for(int j=n-1; j>=0; j--) spis_2[par[j]].push_back(j); for(int lvl=1; lvl<20; lvl++) { for(int v=0; v<n; v++) { if(tree_2[lvl-1][v]==-1) tree_2[lvl][v]=-1; else tree_2[lvl][v]=tree_2[lvl-1][tree_2[lvl-1][v]]; } } } int be[400005], en[400005]; void renumerate(int v) { new_nom[v]=tek_nom; be[v]=tek_nom; tek_nom++; int brs=spis_1[v].size(); for(int i=0; i<brs; i++) { renumerate(spis_1[v][i]); } en[v]=tek_nom-1; } int brv=0; vector<int> Eut; int fir[400005], las[400005]; void euler_tour(int v) { Eut.push_back(v); fir[v]=brv; las[v]=brv; brv++; int brs=spis_2[v].size(); for(int i=0; i<brs; i++) { euler_tour(spis_2[v][i]); Eut.push_back(v); las[v]=brv; brv++; } } int ans[400005]; vector<int> id_beg[400005], id_las[400005]; std::vector<int> check_validity(int N, std::vector<int> X, std::vector<int> Y, std::vector<int> S, std::vector<int> E, std::vector<int> L, std::vector<int> R) { q=S.size(); n=N; m=X.size(); for(int i=0; i<m; i++) { gr[X[i]].push_back(Y[i]); gr[Y[i]].push_back(X[i]); } memset(par, -1, sizeof(par)); for(int j=n-1; j>=0; j--) { compn[brcomp].push_back(j); nom_comp[j]=brcomp; par_comp[brcomp]=j; brcomp++; int brs=gr[j].size(); for(int i=0; i<brs; i++) { int nv=gr[j][i]; if(nv<j || nom_comp[j]==nom_comp[nv]) continue; par[par_comp[nom_comp[nv]]]=j; if(compn[nom_comp[j]].size()>compn[nom_comp[nv]].size()) { int old_comp=nom_comp[nv]; for(int k=0; k<compn[old_comp].size(); k++) { int tv=compn[nom_comp[nv]][k]; nom_comp[tv]=nom_comp[j]; compn[nom_comp[j]].push_back(tv); } par_comp[nom_comp[j]]=j; compn[old_comp].resize(0); } else { int old_comp=nom_comp[j]; for(int k=0; k<compn[old_comp].size(); k++) { int tv=compn[nom_comp[j]][k]; nom_comp[tv]=nom_comp[nv]; compn[nom_comp[nv]].push_back(tv); } par_comp[nom_comp[j]]=j; compn[old_comp].resize(0); } } } build_tree_1(); for(int i=0; i<brcomp; i++) {compn[i].resize(0); nom_comp[i]=0; par[i]=par_comp[i]=-1;} brcomp=0; for(int j=0; j<n; j++) { compn[brcomp].push_back(j); nom_comp[j]=brcomp; par_comp[brcomp]=j; brcomp++; int brs=gr[j].size(); for(int i=0; i<brs; i++) { int nv=gr[j][i]; if(nv>j || nom_comp[j]==nom_comp[nv]) continue; par[par_comp[nom_comp[nv]]]=j; if(compn[nom_comp[j]].size()>compn[nom_comp[nv]].size()) { int old_comp=nom_comp[nv]; for(int k=0; k<compn[old_comp].size(); k++) { int tv=compn[nom_comp[nv]][k]; nom_comp[tv]=nom_comp[j]; compn[nom_comp[j]].push_back(tv); } par_comp[nom_comp[j]]=j; compn[old_comp].resize(0); } else { int old_comp=nom_comp[j]; for(int k=0; k<compn[old_comp].size(); k++) { int tv=compn[nom_comp[j]][k]; nom_comp[tv]=nom_comp[nv]; compn[nom_comp[nv]].push_back(tv); } par_comp[nom_comp[j]]=j; compn[old_comp].resize(0); } } } build_tree_2(); renumerate(0); euler_tour(n-1); for(int i=0; i<q; i++) { for(int lvl=19; lvl>=0; lvl--) { if(tree_1[lvl][S[i]]==-1) continue; else if(tree_1[lvl][S[i]]>=L[i]) S[i]=tree_1[lvl][S[i]]; } for(int lvl=19; lvl>=0; lvl--) { if(tree_2[lvl][E[i]]==-1) continue; else if(tree_2[lvl][E[i]]<=R[i]) E[i]=tree_2[lvl][E[i]]; } //cout<<S[i]<<' '<<E[i]<<endl; if(fir[E[i]]) id_beg[fir[E[i]]-1].push_back(i); id_las[las[E[i]]].push_back(i); //cout<<fir[E[i]]<<" "<<las[E[i]]<<endl; } ///for(int i=0; i<n; i++) //cout<<fir[i]<<" "<<las[i]<<" "; //cout<<endl; ///for(int i=0; i<n; i++) //cout<<new_nom[i]<<" "; //cout<<endl; ///for(int i=0; i<n; i++) //cout<<tree_2[0][i]<<" "; //cout<<endl; for(int i=0; i<Eut.size(); i++) { update(new_nom[Eut[i]]); //cout<<new_nom[Eut[i]]<<" "; for(int j=0; j<id_beg[i].size(); j++) { ans[id_beg[i][j]]-=query(be[S[id_beg[i][j]]], en[S[id_beg[i][j]]]); //cout<<id_beg[i][j]<<" "<<be[S[id_beg[i][j]]]<<" "<<en[S[id_beg[i][j]]]<<endl; } for(int j=0; j<id_las[i].size(); j++) { ans[id_las[i][j]]+=query(be[S[id_las[i][j]]], en[S[id_las[i][j]]]); //cout<<id_las[i][j]<<" "<<be[S[id_las[i][j]]]<<" "<<en[S[id_las[i][j]]]<<endl; } } vector<int> A; A.resize(q); for(int i=0; i<q; i++) A[i]=bool(ans[i]); return A; }

Compilation message (stderr)

werewolf.cpp: In function 'std::vector<int> check_validity(int, std::vector<int>, std::vector<int>, std::vector<int>, std::vector<int>, std::vector<int>, std::vector<int>)':
werewolf.cpp:157:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  157 |         for(int k=0; k<compn[old_comp].size(); k++)
      |                      ~^~~~~~~~~~~~~~~~~~~~~~~
werewolf.cpp:169:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  169 |         for(int k=0; k<compn[old_comp].size(); k++)
      |                      ~^~~~~~~~~~~~~~~~~~~~~~~
werewolf.cpp:200:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  200 |         for(int k=0; k<compn[old_comp].size(); k++)
      |                      ~^~~~~~~~~~~~~~~~~~~~~~~
werewolf.cpp:212:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  212 |         for(int k=0; k<compn[old_comp].size(); k++)
      |                      ~^~~~~~~~~~~~~~~~~~~~~~~
werewolf.cpp:253:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  253 |   for(int i=0; i<Eut.size(); i++)
      |                ~^~~~~~~~~~~
werewolf.cpp:257:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  257 |     for(int j=0; j<id_beg[i].size(); j++)
      |                  ~^~~~~~~~~~~~~~~~~
werewolf.cpp:262:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  262 |     for(int j=0; j<id_las[i].size(); j++)
      |                  ~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...