#include<iostream>
#include<set>
using namespace std;
struct node{
int id1, id2;
};
int main(){
int n, m, k;
scanf("%d%d", &n, &m);
node edge[10010];
for(int i = 0; i < m; i++){
scanf("%d%d", &edge[i].id1, &edge[i].id2);
}
scanf("%d", &k);
for(int i = 0; i < k; i++){
int num, v;
set<int> temp;
scanf("%d", &num);
for(int j = 0; j < num; j++){
scanf("%d", &v);
temp.insert(v);
}
int flag = true;
for(int j = 0; j < m; j++){
if(temp.find(edge[j].id1) == temp.end() &&
temp.find(edge[j].id2) == temp.end()){
printf("No\n");
flag = false;
break;
}
}
if(flag) printf("Yes\n");
}
return 0;
}
原文:https://www.cnblogs.com/tsruixi/p/13096568.html