事实上,这道题并不需要拓扑排序。(当然,拓扑排序还是更快)

  • 题目分析

    首先,题目中说了,这是一个有向无环图,所以,我们可以考虑 \(\texttt{DP}\) / 记搜 / 拓扑排序 来解决这道题。

    (我的做法是记忆化搜索。

  • 雷区分析

    刚开始我用 \(f[i]\) 表示从 \(i\) 出发能够到达的点的个数,利用记忆化搜索更新状态。

    \(f[i] = f[枚举所有出边] + 1\)

    代码如下:

    #include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm> using namespace std; const int N = 30010; int f[N];
int n, m;
int h[N], e[N], ne[N], idx; void add(int a, int b)
{
e[ ++ idx] = b, ne[idx] = h[a], h[a] = idx;
} void dfs(int u)
{
if (f[u]) return;
int s = 1; for (int i = h[u]; i; i = ne[i])
{
int j = e[i];
dfs(j);
s += f[j];
} f[u] += s;
} int main()
{
scanf("%d%d", &n, &m); for (int i = 1, x, y; i <= m; i ++ )
scanf("%d%d", &x, &y), add(x, y); for (int i = 1; i <= n; i ++ )
if (!f[i])
dfs(i); for (int i = 1; i <= n; i ++ )
printf("%d\n", f[i]); return 0;
}

然鹅,我们没有考虑到一种情况,如图:

如果按照刚才上面的做法,那么 \(5, 6\) 号节点就会被统计两次,造成结果偏大。

所以,我们需要记录一下每个出点可到点的并集,这可以用 \(bitset\) 来实现

  • \(bitset\) 用法

    1. \(bitset\) 可以实现二进制运算的 |, ^, & 等操作。
    2. \(bitset.any()\) 返回 \(bitset\) 中是否有 \(1\)
    3. \(bitset.none()\) 返回 \(bitset\) 中是否全为 \(0\)
  • \(\texttt{Code}\)

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <bitset> using namespace std; const int N = 30010;
int n, m;
int h[N], e[N], ne[N], idx;
bitset<N> f[N]; void add(int a, int b)
{
e[ ++ idx] = b, ne[idx] = h[a], h[a] = idx;
} void dfs(int u)
{
if (f[u].any()) return; f[u][u] = 1;
bitset<N> s; for (int i = h[u]; i; i = ne[i])
{
int j = e[i];
dfs(j);
s |= f[j];
} f[u] |= s;
} int main()
{
scanf("%d%d", &n, &m); while (m -- )
{
int a, b;
scanf("%d%d", &a, &b);
add(a, b);
} for (int i = 1; i <= n; i ++ )
if (f[i].none())
dfs(i); for (int i = 1; i <= n; i ++ )
printf("%d\n", f[i].count()); return 0;
}

[Acwing 164. 可达性统计] 题解报告的更多相关文章

  1. AcWing 164. 可达性统计

    给定一张N个点M条边的有向无环图,分别统计从每个点出发能够到达的点的数量. 输入格式 第一行两个整数N,M,接下来M行每行两个整数x,y,表示从x到y的一条有向边. 输出格式 输出共N行,表示每个点能 ...

  2. AcWing P164 可达性统计 题解

    Analysis 这道题我一开始想到的是传递闭包,但是时间复杂度是n³,也开不下30000*30000的数组,所以我想到了拓扑+状态压缩(bitset),从后往前找,把能到达的点能到哪里用位运算赋到上 ...

  3. 「CH2101」可达性统计 解题报告

    CH2101 可达性统计 描述 给定一张N个点M条边的有向无环图,分别统计从每个点出发能够到达的点的数量.N,M≤30000. 输入格式 第一行两个整数N,M,接下来M行每行两个整数x,y,表示从x到 ...

  4. AcWing:164. 可达性统计(拓扑排序 + 状态压缩算法)

    给定一张N个点M条边的有向无环图,分别统计从每个点出发能够到达的点的数量. 输入格式 第一行两个整数N,M,接下来M行每行两个整数x,y,表示从x到y的一条有向边. 输出格式 输出共N行,表示每个点能 ...

  5. CFEducational Codeforces Round 66题解报告

    CFEducational Codeforces Round 66题解报告 感觉丧失了唯一一次能在CF上超过wqy的机会QAQ A 不管 B 不能直接累计乘法打\(tag\),要直接跳 C 考虑二分第 ...

  6. 牛客 51011 可达性统计(拓扑排序,bitset)

    牛客 51011 可达性统计(拓扑排序,bitset) 题意: 给一个 n个点,m条边的有向无环图,分别统计每个点出发能够到达的点的数量(包括自身) \(n,m\le30000\). 样例: 10 1 ...

  7. 2015浙江财经大学ACM有奖周赛(一) 题解报告

    2015浙江财经大学ACM有奖周赛(一) 题解报告 命题:丽丽&&黑鸡 这是命题者原话. 题目涉及的知识面比较广泛,有深度优先搜索.广度优先搜索.数学题.几何题.贪心算法.枚举.二进制 ...

  8. cojs 强连通图计数1-2 题解报告

    OwO 题目含义都是一样的,只是数据范围扩大了 对于n<=7的问题,我们直接暴力搜索就可以了 对于n<=1000的问题,我们不难联想到<主旋律>这一道题 没错,只需要把方程改一 ...

  9. cojs 二分图计数问题1-3 题解报告

    OwO 良心的FFT练手题,包含了所有的多项式基本运算呢 其中一部分解法参考了myy的uoj的blog 二分图计数 1: 实际是求所有图的二分图染色方案和 我们不妨枚举这个图中有多少个黑点 在n个点中 ...

  10. 题解报告:hdu 1398 Square Coins(母函数或dp)

    Problem Description People in Silverland use square coins. Not only they have square shapes but also ...

随机推荐

  1. 看完这篇HTTP,跟面试官扯皮就没问题了(转)

    认识 HTTP 首先你听的最多的应该就是 HTTP 是一种 超文本传输协议(Hypertext Transfer Protocol),这你一定能说出来,但是这样还不够,假如你是大厂面试官,这不可能是他 ...

  2. 个人理解strcpy

    char * strcpy(char *dst,const char *src) { if((dst==NULL)||(src==NULL)) return NULL; char *ret = dst ...

  3. ERROR: <bits/stdc++.h>, 'cstdalign' file not found, running C++17

    Modified 1 year, 1 month ago Viewed 9k times 4 I'm trying to run a piece of code in Visual Studio Co ...

  4. CF707B

    题目简化和分析: 这题看着玄胡很水实际. 我们需要做什么? 只需对每个工厂周围的面包店遍历一遍打擂台取最小 注意只对面包店遍历,所以对工厂设标记 如果打完擂台发现 \(ans=inf\) 则说明全是工 ...

  5. P8679 [蓝桥杯 2019 省 B] 填空问题 题解

    P8679 [蓝桥杯 2019 省 B] 填空问题 题解 题目传送门 欢迎大家指出错误并联系这个蒟蒻 更新日志 2023-05-25 21:02 文章完成 2023-05-27 11:34 文章通过审 ...

  6. 从零用VitePress搭建博客教程(5) - 如何自定义页面模板、给页面添加独有的className和使页面标题变成侧边目录?

    接上一节:从零用VitePress搭建博客教程(4) – 如何自定义首页布局和主题样式修改? 上一节其实我们也简单说了自定义页面模板,这一节更加详细一点说明,开始之前我们要知道在vitePress中, ...

  7. js排序算法--冒泡排序

    <!DOCTYPE html> <html> <head> <title></title> </head> <body&g ...

  8. Python网页应用开发神器fac 0.2.10版本新功能介绍

    fac项目地址:https://github.com/CNFeffery/feffery-antd-components 欢迎star支持 大家好我是费老师,由我开源维护的Python网页通用组件库f ...

  9. RLChina2022公开课-博弈论

    纯博弈: 单纯的动机组合,离散的集合 混合博弈: 加入了概率论,以百分比的概率执行不同的的动机.,概率分布 零和博弈.合作博弈.协同博弈 扩展博弈和非完美信息 扩展博弈.贝叶斯博弈 纳什均衡 任何一位 ...

  10. JUC并发编程学习笔记(四)8锁现象

    8锁现象 八锁->就是关于锁的八个问题 锁是什么,如何判断锁的是谁 对象.class模板 深刻理解锁 锁的东西无外乎就两样:1.同步方法的调用者,2.Class模板. 同一个锁中,只有当前线程资 ...