这道题果然采用了BFS来遍历,没神马太高的难度,注意的点有以下几点:
1.输入的节点和之前不同,是b->a;
2.每次迭代之后要注意VIs数组的更新;
3.示例采用的方法并不是按层数计数,而是节点内置层数信息,从而化简了层数判断的代码;
详细代码如下所示:
#include<stdio.h>
#include<stdlib.h>
#include<vector>
#include<queue>
#include<cstring>
#include<iostream>
using namespace std;
using std::vector;
const int MAXV=1010;
struct Node{
int id;
int layer;
};
vector<Node> Adj[MAXV];
bool inq[MAXV]={false};
int BFS(int s,int L){
int numForward=0;
queue<Node>q;
Node start;
start.id=s;
start.layer=0;
q.push(start);
inq[start.id]=true;
while(!q.empty()){
Node topNode=q.front();
q.pop();
int u=topNode.id;
for(int i=0;i<Adj[u].size();i++){
Node next=Adj[u][i];
next.layer=topNode.layer+1;
if(inq[next.id]==false&&next.layer<=L){
q.push(next);
inq[next.id]=true;
numForward++;
}
}
}
return numForward;
}
int main(){
Node user;
int n,L,numFollow,idFollow;
scanf("%d%d",&n,&L);
for(int i=1;i<=n;i++){
user.id=i;
scanf("%d",&numFollow);
for(int j=0;j<numFollow;j++){
scanf("%d",&idFollow);
Adj[idFollow].push_back(user);
}
}
int numQuery,s;
scanf("%d",&numQuery);
for(int i=0;i<numQuery;i++){
memset(inq,false,sizeof(inq));
scanf("%d",&s);
int numForward=BFS(s,L);
printf("%d\n",numForward);
}
system("pause");
return 0;
}