2013年8月12日

UVa 11518 - Dominos 2

#include <cstdio>
#include <vector>
#define PB push_back
using namespace std;

vector<int> con[10001];
bool vis[10001];
int fall;

void push(int x) {
  if (vis[x]) {
    return;
  }
  fall++;
  vis[x] = true;
  for (int i = 0; i < con[x].size(); i++) {
    if (!vis[con[x][i]]) {
      push(con[x][i]);
    }
  }
}

int main() {
  int T;
  scanf("%d", &T);
  while (T--) {
    int n, m, l;
    scanf("%d%d%d", &n, &m, &l);
    for (int i = 0; i <= n; i++) {
      con[i].clear();
      vis[i] = false;
    }
    while (m--) {
      int x, y;
      scanf("%d%d", &x, &y);
      con[x].PB(y);
    }
    fall = 0;
    while (l--) {
      int z;
      scanf("%d", &z);
      push(z);
    }
    printf("%d\n", fall);
  }
  return 0;
}

沒有留言:

張貼留言