제출 #311550

#제출 시각아이디문제언어결과실행 시간메모리
311550hoangtung_proRailway (BOI17_railway)C++14
0 / 100
233 ms45176 KiB
#include<bits/stdc++.h> #define endl '\n' #define fi first #define se second #define pb push_back #define bit(s, i) (s & (1<<i)) using namespace std; const int maxn = 1e5 + 5; const int mod = 1e9+7; typedef long long ll; typedef pair < int, int > ii; int n, m, k; vector < ii > adj[maxn]; vector < int > child[maxn]; bool vis[maxn]; int h[maxn]; int id[maxn]; int p[maxn][20]; void ht(int v) { vis[v] = true; for(ii u : adj[v]) if(!vis[u.fi]) { p[u.fi][0] = v; h[u.fi] = h[v] + 1; id[u.fi] = u.se; child[v].pb(u.fi); ht(u.fi); } } int LCA(int u, int v) { if(h[u] > h[v]) swap(u, v); for(int i=18;i>=0;--i) if( h[p[v][i]] >= h[u] ) v = p[v][i]; if(u == v) return u; for(int i=18;i>=0;--i) { if( p[u][i] != p[v][i] ) { u = p[u][i]; v = p[v][i]; } } return p[u][0]; } set < int > query[maxn]; vector < int > requery[maxn], res; void cal(int v) { for(int u : child[v]) { cal(u); if(query[u].size() > query[v].size()) swap(query[u], query[v]); for(int x : query[u]) query[v].insert(x); } for(int x : requery[v]) query[v].erase(x); } int main() { ios::sync_with_stdio(0);cin.tie(0);cout.tie(0); //freopen(".inp","r",stdin); //freopen(".out","w",stdout); cin >> n >> m >> k; for(int i=1;i<n;++i) { int u, v; cin >> u >> v; adj[u].pb( ii(v, i) ); adj[v].pb( ii(u, i) ); } h[0] = -1; ht(1); for(int j=1;j<=18;++j) for(int i=1;i<=n;++i) if((1<<j) <= h[i]) p[i][j] = p[p[i][j-1]][j-1]; for(int i=1, s;i<=m;++i) { cin >> s; int ro; for(int j=1, x;j<=s;++j) { cin >> x; query[x].insert(i); if(j == 1) ro = x; else ro = LCA(ro, x); } requery[ro].pb(i); } cal(1); for(int i=1;i<=n;++i) if(query[i].size() >= k) res.pb(i); cout << res.size() << endl; for(int x : res) cout << id[x] << ' '; }

컴파일 시 표준 에러 (stderr) 메시지

railway.cpp: In function 'int main()':
railway.cpp:110:46: warning: comparison of integer expressions of different signedness: 'std::set<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
  110 |     for(int i=1;i<=n;++i) if(query[i].size() >= k) res.pb(i);
      |                              ~~~~~~~~~~~~~~~~^~~~
#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...