2018杭电多校第六场1009(DFS,思维)
#include<bits/stdc++.h>
using namespace std;
int a[100010];
char s[20];
int zhiren[100010];
vector<int>haoren[100010];
int sum=0;
void dfs(int x,int y,int flag)
{
if(x==y)
flag=1;//如果和被指认的人相同,则定为狼
sum+=flag;//并且后面直接或间接认为刚才那个是狼的人是好人的人也都是狼
for(int i=0;i<haoren[y].size();i++)
{
dfs(x,haoren[y][i],flag);//搜索认为指认他人是狼人的这个人是好人的人
}
return;
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
sum=0;
int n;
scanf("%d",&n);
memset(zhiren,0,sizeof(zhiren));
for(int i=0;i<=n;i++)
{
haoren[i].clear();
}
for(int i=1;i<=n;i++)
{
scanf("%d%s",&a[i],s);
if(s[0]=='v')
{
haoren[a[i]].push_back(i);//把认为a[i]是好人的人i放入向量中
}
else
{
zhiren[i]=a[i];//i认为a[i]是狼人
}
}
for(int i=1;i<=n;i++)
{
if(zhiren[i])//找到第一个被认为是狼人的人
{
dfs(zhiren[i],i,0);//从这个人开始dfs
}
}
printf("0 %d\n",sum);//所有人都是狼人的情况是成立的
}
return 0;
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步