Submission #714667

#TimeUsernameProblemLanguageResultExecution timeMemory
714667TheSahibStranded Far From Home (BOI22_island)C++14
10 / 100
1069 ms195056 KiB
#include <bits/stdc++.h> #define ll long long #define pii pair<int, int> using namespace std; const int MAX = 2e5 + 5; int n, m; int arr[MAX]; vector<int> g[MAX]; bool visited[MAX]; bool bfs(int start){ fill(visited, visited + n + 1, 0); ll cnt = 0; set<pii> q; q.insert({arr[start], start}); while(!q.empty()){ int node = q.begin()->second; int c = q.begin()->first; q.erase(q.begin()); visited[node] = true; if(cnt >= c || node == start){ cnt += c; for(int to:g[node]){ if(visited[to]) continue; q.insert({arr[to], to}); } } else{ return false; } } return true; } int subTree[MAX]; bool possible[MAX]; int dfs1(int node, int p){ int ans = arr[node]; for(int to:g[node]){ if(to == p) continue; ans += dfs1(to, node); } subTree[node] = ans; return ans; } void dfs2(int node, int p){ if(node == 1){ possible[node] = 1; } else{ possible[node] = ((subTree[node] >= arr[p]) && possible[p]); } if(!possible[node]) return; for(int to:g[node]){ if(to == p) continue; dfs2(to, node); } } int main(){ cin >> n >> m; for (int i = 1; i <= n; i++) { cin >> arr[i]; } for (int i = 0; i < m; i++) { int a, b; cin >> a >> b; g[a].emplace_back(b); g[b].emplace_back(a); } if(n > 2000 || m > 2000){ dfs1(1, 1); dfs2(1, 1); for (int i = 1; i <= n; i++) { cout << possible[i]; } return 0; } for (int i = 1; i <= n; i++) { cout << bfs(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...