华硕ac5300最牛设置_acwing是什么

华硕ac5300最牛设置_acwing是什么每一头牛的愿望就是变成一头最受欢迎的牛。现在有 N 头牛,编号从 1 到 N,给你 M 对整数 (A,B),表示牛 A 认为牛 B 受欢迎。这种关系是具有传递性的,如果 A 认为 B 受欢迎,B 认为 C 受欢迎,那么牛 A 也认为牛 C 受欢迎。你的任务是求出有多少头牛被除自己之外的所有牛认为是受欢迎的。输入格式第一行两个数 N,M;接下来 M 行,每行两个数 A,B,意思是 A 认为 B 是受欢迎的(给出的信息有可能重复,即有可能出现多个 A,B)。输出格式输出被除自己之外的所有牛认为是

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

每一头牛的愿望就是变成一头最受欢迎的牛。

现在有 N 头牛,编号从 1 到 N,给你 M 对整数 (A,B),表示牛 A 认为牛 B 受欢迎。

这种关系是具有传递性的,如果 A 认为 B 受欢迎,B 认为 C 受欢迎,那么牛 A 也认为牛 C 受欢迎。

你的任务是求出有多少头牛被除自己之外的所有牛认为是受欢迎的。

输入格式
第一行两个数 N,M;

接下来 M 行,每行两个数 A,B,意思是 A 认为 B 是受欢迎的(给出的信息有可能重复,即有可能出现多个 A,B)。

输出格式
输出被除自己之外的所有牛认为是受欢迎的牛的数量。

数据范围
1≤N≤104,
1≤M≤5×104

输入样例:
3 3
1 2
2 1
2 3
输出样例:
1

样例解释
只有第三头牛被除自己之外的所有牛认为是受欢迎的。

题解
Tarjan

#include<bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
const int M = 5e4 + 10;
struct Edge{ 
   
    int v,next,w;
}edge[M];
int head[N],cnt;
int low[N],num[N],dfn;
int sccno[N],sta[N],bcc,top;
bool in_stack[N];
int out[N],Size[N];
void add(int u,int v){ 
   
    edge[cnt].v = v;
    edge[cnt].next = head[u];
    head[u] = cnt ++;
}
void Tarjan(int u){ 
   
    low[u] = num[u] = ++ dfn;
    sta[top ++] = u,in_stack[u] = true;
    for(int i = head[u];~i;i = edge[i].next){ 
   
        int v = edge[i].v;
        if(!num[v]){ 
   
            Tarjan(v);
            low[u] = min(low[u],low[v]);
        }
        else if(in_stack[v])
            low[u] = min(low[u],num[v]);
    }
    if(low[u] == num[u]){ 
   
        bcc ++;
        int t;
        do{ 
   
            Size[bcc] ++;
            t = sta[-- top];
            in_stack[t] = false;
            sccno[t] = bcc;
        }while(t != u);
    }
}

int main(){ 
   
    memset(head,-1,sizeof head);
    int n,m;
    cin>>n>>m;
    int x,y;
    for(int i = 0;i < m;i ++){ 
   
        cin>>x>>y;
        add(x,y);
    }
    for(int i = 1;i <= n;i ++){ 
   
        if(!num[i])Tarjan(i);
    }
    for(int i = 1;i <= n;i ++){ 
   
        for(int j = head[i];~j;j = edge[j].next){ 
   
            int a = sccno[i],b = sccno[edge[j].v];
            if(a != b)out[a] ++;
        }
    }
    int count = 0;
    int c = 0;
    for(int i = 1;i <= bcc;i ++){ 
   
        if(!out[i]){ 
   
            c ++;
        
            count += Size[i];
        }
    }
    if(c == 1)cout<<count<<endl;
    else cout<<0<<endl;
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169109.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月10日 下午8:36
下一篇 2022年8月10日 下午8:46


相关推荐

  • 在css中如何使用cursor设置鼠标样式

    在css中如何使用cursor设置鼠标样式

    2026年3月16日
    3
  • 服务器更改存储位置,WSUS补丁存放位置变更

    服务器更改存储位置,WSUS补丁存放位置变更你好 如果您的磁盘已满 您可以安装更大的磁盘 然后将更新文件移动到新的位置 为此 创建新的磁盘驱动器后 您将需要运行 WSUSutil exe 工具 使用 movecontent 命令 将更新文件移动到新磁盘 更改本地 WSUS 更新存储的位置 1 以本地管理员身份登录到 WSUS 服务器 2 在目标分区建立文件夹以存放更新文件如 e wsus 3 打开一个 CMD 命令行窗口 然后进入以下路径 C program

    2026年3月17日
    2
  • mysql 字段判断是否存在_mysql 新增字段时判断字段是否存在

    mysql 字段判断是否存在_mysql 新增字段时判断字段是否存在1 问题引出为了保证数据的正确性 代码的健壮性 我们必须对一些边界条件做一个判断 所以才会把修改表结构搞得如此复杂 mysql 新增字段时判断字段是否存在 本来是一个很小的问题 因为以前都是使用 postgreSql sqlserver 上来就 ifnotexist 结果 mysql 并不吃这一套 看看这段代码 IFNOTEXISTS SELECT1FROMI

    2026年3月18日
    2
  • unittest 测试框架

    unittest 测试框架一、unittest测试框架1、测试固件1.1setUp()1.2tearDown()2、unittest基本使用3、测试套件(suit)3.1测试用例执行顺序3.2忽略测试用例的执行4、断言5、HTML报告生成5.1测试报告5.2异常捕捉与错误截图5.2.1错误截图:get_scunittest是python的单元测试框架,unittest单元测试提供了创建测试用例,测试套件以及批量执行的方案。作为单元测试的框架,unittest也是可以对程序最小

    2022年10月15日
    5
  • sql语句查询前100条数据_sql取前100条数据

    sql语句查询前100条数据_sql取前100条数据mysql查询前100条数据云服务器(ElasticComputeService,简称ECS)是阿里云提供的性能卓越、稳定可靠、弹性扩展的IaaS(InfrastructureasaService)级别云计算服务。云服务器ECS免去了您采购IT硬件的前期准备,让您像使用水、电、天然气等公共资源一样便捷、高效地使用服务器,实现计算资源的即开即用和弹性伸缩。阿里云ECS持续提供创新型服务器,…

    2025年10月4日
    5
  • 图论算法详解

    图论算法详解一 图的表示 1 1 邻接矩阵一个一维数组存储顶点 一个二维数组存储边 稠密图首选邻接矩阵 如果顶点太多了 比如说有个顶点 要开辟 mpt 这么大的数组 空间超出限制 则考虑用邻接表 同时 如果图比较稀疏 也可考虑用邻接表 下面演示邻接矩阵的存储过程 include bits stdc h usingnamespa intmpt 105 105 intn m n 个点 m 条边 defineIN bits

    2026年3月19日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号