Submission #1307143

#TimeUsernameProblemLanguageResultExecution timeMemory
1307143DangKhoizzzzThe Xana coup (BOI21_xanadu)C++20
100 / 100
45 ms22356 KiB
#include <bits/stdc++.h> #define int long long #define fi first #define se second #define pii pair <int , int> #define arr3 array <int , 3> using namespace std; const int INF = 1e18; const int maxn = 120003; const int mod = 998244353; int n , f[maxn][2][2] , val[maxn]; vector <int> g[maxn]; void chmin(int &a , int b) {a = min(a , b);} // dinh u / chon hoac ko chon / gia tri dinh void dfs(int u , int p) { for(int x = 0; x < 2; x++) { for(int y = 0; y < 2; y++) f[u][x][y] = INF; } f[u][0][val[u]] = 0; f[u][1][val[u]^1] = 1; for(int v: g[u]) { if(v == p) continue; dfs(v , u); int dp[2][2]; for(int x = 0; x < 2; x++) { for(int y = 0; y < 2; y++) { dp[x][y] = f[u][x][y]; f[u][x][y] = INF; } } for(int a = 0; a < 2; a++) { for(int b = 0; b < 2; b++) { for(int x = 0; x < 2; x++) { for(int y = 0; y < 2; y++) { if((y^a) == 0) chmin(f[u][a][b^x] , dp[a][b] + f[v][x][y]); } } } } } } void solve() { cin >> n; for(int i = 1; i < n; i++) { int u , v; cin >> u >> v; g[u].push_back(v); g[v].push_back(u); } for(int i = 1; i <= n; i++) cin >> val[i]; dfs(1 , 1); int ans = min(f[1][0][0] , f[1][1][0]); if(ans == INF) cout << "impossible" << '\n'; else cout << ans << '\n'; } signed main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); //freopen("inp.txt", "r", stdin); freopen("out.txt", "w", stdout); solve(); return 0; }
#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...