zoukankan      html  css  js  c++  java
  • 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 ",sum);//所有人都是狼人的情况是成立的
        }
        return 0;
    }

    保持热爱 不懈努力 不试试看怎么知道会失败呢(划掉) 世上无难事 只要肯放弃(划掉)
  • 相关阅读:
    oracle“记录被另一个用户锁住”
    Oracle CASE WHEN 用法介绍
    拥有机器人的人生会是怎样的体验?
    需求那么多,核心需求都从哪里来?
    一文读懂互联网及电商逻辑
    读书:《敏捷产品--不确定性的思维革命》
    读书:《超越感觉:批判性思考指南》一
    618啦,你的钱包又被盯上啦!
    产品经理如何开启上帝视角?
    我的产品经理价值观
  • 原文地址:https://www.cnblogs.com/ldudxy/p/9489358.html
Copyright © 2011-2022 走看看