Josif_tepe

Untitled

Oct 1st, 2025
123
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.77 KB | None | 0 0
  1. #include <queue>
  2. #include <iostream>
  3. #include <vector>
  4. #include <cstring>
  5. #include <iostream>
  6. #include <set>
  7. #include <map>
  8. #include <cstring>
  9. //#include <bits/stdc++.h>
  10. using namespace std;
  11.  
  12. const int maxn = 100005;
  13. vector<int> adj[maxn];
  14. int owner[maxn]; //ke zemam 0 za nicija sopstvenost, 1 za kosta, 2 za kiril
  15. int distArr[maxn];
  16.  
  17. //plan: treba modificiran bfs za sekoja startna pozicija
  18.  
  19. int bfs(vector<int> starts, int P) {
  20.     queue<int> q;
  21.     vector<bool> visited(maxn, false);
  22.  
  23.     for (int s : starts) {
  24.         q.push(s);
  25.         distArr[s] = 0;
  26.         visited[s] = true;
  27.     }
  28.  
  29.     int cnt = 0;
  30.  
  31.     while (!q.empty()) {
  32.         int u = q.front();
  33.         q.pop();
  34.  
  35.         for (int v : adj[u]) {
  36.             if(owner[v] == 2){
  37.                 continue;
  38.             }
  39.             if(visited[v]){
  40.                 continue;
  41.             }
  42.  
  43.                 visited[v] = true;
  44.                 if(owner[v] == 0){
  45.                     owner[v] = 1;
  46.                     cnt++;
  47.                 }
  48.                 q.push(v);
  49.             }
  50.         }
  51.    
  52.  
  53.     return cnt;
  54. }
  55.  
  56. int main() {
  57.     ios::sync_with_stdio(false);
  58.  
  59.     int n, b1, b2, p;
  60.     cin >> n >> b1 >> b2 >> p;
  61.  
  62.     vector<int> kosta(b1), kiril(b2);
  63.  
  64.     for (int i = 0; i < b1; i++){
  65.         cin >> kosta[i];
  66.         owner[kosta[i]] = 1;
  67.     }
  68.     for (int i = 0; i < b2; i++){
  69.         cin >> kiril[i];
  70.         owner[kiril[i]] = 2;
  71.     }
  72.  
  73.     int m; cin >> m;
  74.     for (int i = 0; i < m; i++){
  75.         int a, b;
  76.         cin >> a >> b;
  77.         adj[a].push_back(b);
  78.         adj[b].push_back(a);
  79.     }
  80.  
  81.     for (int i = 1; i <= n; i++){
  82.         distArr[i] = -1;
  83.     }
  84.  
  85.     int newCities = bfs(kosta, p);
  86.     cout << min(newCities, p) << endl;
  87.  
  88.     return 0;
  89. }
  90.  
Advertisement
Add Comment
Please, Sign In to add comment