Submission #1056796

#TimeUsernameProblemLanguageResultExecution timeMemory
1056796kachim2The Xana coup (BOI21_xanadu)C++17
0 / 100
1067 ms5712 KiB
#include<bits/stdc++.h> using namespace std; vector<vector<long>> tree; long N; long bst = LONG_MAX; int main(){ long n; cin >> n; N=n; tree.resize(n); vector<bool> lit(n, 0); for(long i = 0; i < n-1; i++){ long a, b; cin >> a >> b; tree[a-1].push_back(b-1); tree[b-1].push_back(a-1); } for(long i = 0; i < n; i++){ long x;cin >> x; lit[i] = x; } for(int i = 0; i < 1<<(n); i++){ auto flit = lit; int fi = i; int cnt = 0; long scntl= 0; while(fi!=0){ if(fi&1){ scntl++; for(auto j : tree[cnt]){ flit[j] = !flit[j]; } flit[cnt] = ! flit[cnt]; } fi>>=1; cnt++; } bool bad = 0; for(int i = 0; i < n; i++) if(flit[i]) bad=1; if(!bad){ bst = min(bst, scntl); } } if(bst == LONG_MAX) cout << "imposible"; else cout << bst; }
#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...