// #pragma GCC optimize ("Ofast") // #pragma GCC optimize ("unroll-loops") // #pragma GCC target ("avx,avx2,fma") #include using std::cin, std::cout, std::cerr; using ll = long long; int main() { std::ios::sync_with_stdio(false); int n, m; cin >> n >> m; std::vector> e(n); std::vector a(n); for(int i = 0; i < n; i ++) cin >> a[i]; for(int i = 0; i < m; i ++) { int u, v; cin >> u >> v; u --; v --; e[u].push_back(v); e[v].push_back(u); } int ans = 0; for(int k = 0; k < 1 << n; k ++) { std::vector b(n); for(int i = 0; i < n; i ++) if((k >> i) & 1) for(int j : e[i]) b[j] ++; if(a == b) { cout << "Yes\n"; for(int i = 0; i < n; i ++) if((k >> i) & 1) cout << 1 << ' '; else cout << 0 << ' '; cout << '\n'; return 0; } } cout << "No" << '\n'; }