Submission #285628

#TimeUsernameProblemLanguageResultExecution timeMemory
2856282qbingxuanFriend (IOI14_friend)C++14
Compilation error
0 ms0 KiB
#include "friend.h" #include <bits/stdc++.h> #ifdef local #define debug(...) qqbx(#__VA_ARGS__, __VA_ARGS__) void qqbx(const char *s) {} template <typename H, typename ...T> void qqbx(const char *s, const H& h, T&& ...args) { for(; *s && *s != ','; ++s) if(*s != ' ') std::cerr << *s; std::cerr << " = " << h << (sizeof...(T) ? ", " : "\n"); if(sizeof...(T)) qqbx(++s, args...); } #define safe std::cerr<<__PRETTY_FUNCTION__<<" line "<<__LINE__<<" safe\n" #else #define debug(...) ((void)0) #define safe ((void)0) #endif // local #define pb emplace_back #define all(v) begin(v),end(v) using namespace std; struct Dinic { struct Edge { int rest, to; Edge(int rest, int to) : rest(rest), to(to) {} }; vector<Edge> E; vector<vector<int>> g; int tot; vector<int> dis, cur; Dinic(int _n) : n(_n), g(n), tot(0), dis(n), cur(n) {} void addEdge(int a, int b, int c) { g[a].pb(E.size()), E.pb(c, b); g[b].pb(E.size()), E.pb(0, a); } bool BFS(int s, int t) { fill(dis.begin(), dis.end(), -1); queue<int> q; dis[s] = 0; q.push(s); while(!q.empty()) { int i = q.front(); q.pop(); for(int id: g[i]) if(E[id].rest > 0 && dis[E[id].to] == -1) { dis[E[id].to] = dis[i] + 1; q.push(E[id].to); } } return dis[t] != -1; } int DFS(int i, int t, int lim) { if(i == t) return lim; int ans = 0; while(cur[i] < g[i].size() && lim) { int id = g[i][cur[i]++]; if(dis[E[id].to] != dis[i] + 1) continue; int f = DFS(E[id].to], t, min(lim, E[id].rest)); E[id].rest -= f; E[id^1].rest += f; ans += f; lim -= f; } return ans; } int maxFlow(int s, int t) { int ans = 0; while(BFS(s, t)) { fill(cur.begin(), cur.end(), 0); while(int f = DFS(s, t, 1e9)) ans += f; } return ans; } }; int findSample(int n, int confidence[], int host[], int protocol[]){ int ans = 0; auto isNothing = [&]() -> bool { for(int i = 1; i < n; i++) if(protocol[i] != 1) return false; return true; }; auto isComplete = [&]() -> bool { for(int i = 1; i < n; i++) if(protocol[i] != 2) return false; return true; }; auto isTree = [&]() -> bool { for(int i = 1; i < n; i++) if(protocol[i] != 0) return false; return true; }; auto isBipartite = [&]() -> bool { for(int i = 1; i < n; i++) if(protocol[i] == 2) return false; return true; }; if(isComplete()) { return *max_element(confidence, confidence+n); } if(isTree()) { vector<vector<int>> g(n); vector<array<int,2>> dp(n); for(int i = 1; i < n; i++) g[host[i]].pb(i); function<void(int,int)> dfs = [&](int i, int p) { dp[i][0] = 0, dp[i][1] = confidence[i]; for(int j: g[i]) { if(j == p) continue; dfs(j, i); dp[i][0] += max(dp[j][0], dp[j][1]); dp[i][1] += dp[j][0]; } }; dfs(0, -1); return max(dp[0][0], dp[0][1]); } if(isNothing()) { long long sum = 0; for(int i = 0; i < n; i++) sum += confidence[i]; return sum; } if(isBipartite()) { vector<vector<int>> g(n); for(int i = 1; i < n; i++) { if(protocol[i] == 0) { g[host[i]].pb(i); g[i].pb(host[i]); } else if(protocol[i] == 1) { for(int j: g[host[i]]) { g[j].pb(i); g[i].pb(j); } } } vector<int> col(n); function<bool(int,int)> dfs = [&](int i, int c) -> bool { col[i] = c; for(int j: g[i]) { if(col[j] == 0) { if(!dfs(j, -c)) return false; } else if(col[j] != -col[i]) return false; } return true; }; /* for(int i = 0; i < n; i++) if(col[i] == 0) assert(dfs(i, 1)); */ Dinic flow(n*2+2); int s = n*2+1, t = s+1; for(int i = 0; i < n; i++) { flow.addEdge(s, i); flow.addEdge(i+n, t); } for(int i = 0; i < n; i++) for(int j: g[i]) flow.addEdge(i, j+n); return flow.maxFlow(i, j); } if(n <= 20) { int g[10] = {}; for(int i = 1; i < n; i++) { if(protocol[i] == 0) { g[i] |= 1 << host[i]; g[host[i]] |= 1 << i; } else if(protocol[i] == 1) { g[i] |= g[host[i]]; for(int j = 0; j < n; j++) if(g[host[i]] >> j & 1) g[j] |= 1 << i; } else if(protocol[i] == 2) { g[i] |= g[host[i]]; for(int j = 0; j < n; j++) if(g[host[i]] >> j & 1) g[j] |= 1 << i; g[i] |= 1 << host[i]; g[host[i]] |= 1 << i; } } int ans = 0; /* vector<int> wei(1<<n); */ /* for(int i = 0; i < n; i++) wei[1<<i] = confidence[i]; */ /* for(int s = 0; s < (1<<n); s++) wei[s] += wei[s - (s&-s)]; */ for(int s = 0; s < (1<<n); s++) { bool ok = 1; for(int i = 0; i < n; i++) if((s >> i & 1) && (g[i] & s)) ok = 0; if(ok) { int sum = 0; for(int i = 0; i < n; i++) if(s >> i & 1) sum += confidence[i]; ans = max(ans, sum); } } return ans; } return -1; }

Compilation message (stderr)

friend.cpp: In constructor 'Dinic::Dinic(int)':
friend.cpp:29:21: error: class 'Dinic' does not have any field named 'n'
   29 |     Dinic(int _n) : n(_n), g(n), tot(0), dis(n), cur(n) {}
      |                     ^
friend.cpp:29:30: error: 'n' was not declared in this scope; did you mean 'yn'?
   29 |     Dinic(int _n) : n(_n), g(n), tot(0), dis(n), cur(n) {}
      |                              ^
      |                              yn
friend.cpp: In member function 'int Dinic::DFS(int, int, int)':
friend.cpp:51:22: warning: comparison of integer expressions of different signedness: '__gnu_cxx::__alloc_traits<std::allocator<int>, int>::value_type' {aka 'int'} and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   51 |         while(cur[i] < g[i].size() && lim) {
friend.cpp:54:33: error: expected ')' before ']' token
   54 |             int f = DFS(E[id].to], t, min(lim, E[id].rest));
      |                        ~        ^
      |                                 )
friend.cpp: In function 'int findSample(int, int*, int*, int*)':
friend.cpp:140:30: error: no matching function for call to 'Dinic::addEdge(int&, int&)'
  140 |             flow.addEdge(s, i);
      |                              ^
friend.cpp:30:10: note: candidate: 'void Dinic::addEdge(int, int, int)'
   30 |     void addEdge(int a, int b, int c) {
      |          ^~~~~~~
friend.cpp:30:10: note:   candidate expects 3 arguments, 2 provided
friend.cpp:141:32: error: no matching function for call to 'Dinic::addEdge(int, int&)'
  141 |             flow.addEdge(i+n, t);
      |                                ^
friend.cpp:30:10: note: candidate: 'void Dinic::addEdge(int, int, int)'
   30 |     void addEdge(int a, int b, int c) {
      |          ^~~~~~~
friend.cpp:30:10: note:   candidate expects 3 arguments, 2 provided
friend.cpp:143:72: error: no matching function for call to 'Dinic::addEdge(int&, int)'
  143 |         for(int i = 0; i < n; i++) for(int j: g[i]) flow.addEdge(i, j+n);
      |                                                                        ^
friend.cpp:30:10: note: candidate: 'void Dinic::addEdge(int, int, int)'
   30 |     void addEdge(int a, int b, int c) {
      |          ^~~~~~~
friend.cpp:30:10: note:   candidate expects 3 arguments, 2 provided
friend.cpp:144:29: error: 'i' was not declared in this scope
  144 |         return flow.maxFlow(i, j);
      |                             ^
friend.cpp:144:32: error: 'j' was not declared in this scope
  144 |         return flow.maxFlow(i, j);
      |                                ^
friend.cpp:72:9: warning: unused variable 'ans' [-Wunused-variable]
   72 |     int ans = 0;
      |         ^~~