Submission #197161

#TimeUsernameProblemLanguageResultExecution timeMemory
197161arnold518Political Development (BOI17_politicaldevelopment)C++14
54 / 100
3042 ms25860 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef pair<int, int> pii; typedef pair<ll, ll> pll; const int MAXN = 5e4; int N, K, ans=1; set<int> adj[MAXN+10]; bool vis[MAXN+10]; int main() { int i, j, k; scanf("%d%d", &N, &K); for(i=1; i<=N; i++) { int s; scanf("%d", &s); while(s--) { int t; scanf("%d", &t); adj[i].insert(t+1); } } while(1) { pii t(987654321, 0); for(i=1; i<=N; i++) if(!vis[i]) t=min(t, pii(adj[i].size(), i)); if(t.second==0) break; int now=t.second; vector<int> chd; for(auto it : adj[now]) chd.push_back(it); for(i=0; i<(1<<chd.size()); i++) { vector<int> V; for(j=0; j<chd.size(); j++) if(i&(1<<j)) V.push_back(chd[j]); bool flag=true; for(j=0; j<V.size(); j++) for(k=j+1; k<V.size(); k++) if(adj[V[j]].find(V[k])==adj[V[j]].end()) flag=false; if(flag) ans=max(ans, (int)V.size()+1); } vis[now]=true; for(auto it : chd) adj[it].erase(now); adj[now].clear(); } printf("%d", ans); }

Compilation message (stderr)

politicaldevelopment.cpp: In function 'int main()':
politicaldevelopment.cpp:38:14: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for(j=0; j<chd.size(); j++) if(i&(1<<j)) V.push_back(chd[j]);
             ~^~~~~~~~~~~
politicaldevelopment.cpp:40:14: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for(j=0; j<V.size(); j++) for(k=j+1; k<V.size(); k++) if(adj[V[j]].find(V[k])==adj[V[j]].end()) flag=false;
             ~^~~~~~~~~
politicaldevelopment.cpp:40:42: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    for(j=0; j<V.size(); j++) for(k=j+1; k<V.size(); k++) if(adj[V[j]].find(V[k])==adj[V[j]].end()) flag=false;
                                         ~^~~~~~~~~
politicaldevelopment.cpp:17:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d%d", &N, &K);
  ~~~~~^~~~~~~~~~~~~~~~
politicaldevelopment.cpp:21:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d", &s);
   ~~~~~^~~~~~~~~~
politicaldevelopment.cpp:22:28: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   while(s--) { int t; scanf("%d", &t); adj[i].insert(t+1); }
                       ~~~~~^~~~~~~~~~
#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...