P4017 最大食物链计数

题目:P4017 最大食物链计数

知识点:链式前向星建图、同余原理、拓扑排序、动态规划

CODE:

cpp 复制代码
#include <bits/stdc++.h>
#define MOD 80112002
using namespace std;

static const int N = 5005;
static const int M = 500005;

vector<int> head(N, 0);
vector<int> nxt(M, 0);
vector<int> to(M, 0);

vector<int> idgr(N, 0);
vector<int> odgr(N, 0);

vector<int> dp(N, 0);


int main() {
    int n, m;
    cin >> n >> m;
    int cnt = 1;
    while (m--) {
        int f, t;
        cin >> f >> t;
        // idgr & odgr
        odgr[f]++;
        idgr[t]++;
        // f -> t
        to[cnt] = t;
        nxt[cnt] = head[f];
        head[f] = cnt++;
    }

    // ...
    queue<int> q;
    int ans = 0;
    for (int i = 1; i <= n; i++) {
        if (idgr[i] == 0) {
            q.emplace(i);
            dp[i] = 1;
            if (odgr[i] == 0) {
                ans++;
            }
        }
    }

    while (!q.empty()) {
        int f = q.front();
        q.pop();
        int e = head[f];
        while (e != 0) {
            // 边 e
            int v = to[e];
            idgr[v]--;
            // dp[v] += dp[f];
            dp[v] = ((dp[v] % MOD) + dp[f]) % MOD;
            if (idgr[v] == 0) {
                q.emplace(v);
                if (odgr[v] == 0) {
                    ans = ((ans % MOD) + dp[v]) % MOD;
                }
            }
            e = nxt[e];
        }
    }

    cout << ans << endl;

}

易错点:

①对于孤立点,要计算一次,42line
②对于拓扑排序的终点,是当入度变为 0 时才去判断是否为终点,而不是只要出度为 0 就记录,如下为错误示例,这会导致入度为复数的终点重复计算
cpp 复制代码
// ...
if (idgr[v] == 0) {
  q.emplace(v);
}
if (odgr[v] == 0 {
  ans = ((ans % MOD) + dp[v]) % MOD;
}
相关推荐
吃好睡好便好8 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅9 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
于小猿Sup10 小时前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
x_yeyue11 小时前
三角形数
笔记·算法·数论·组合数学
念何架构之路12 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星12 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
小小编程路12 小时前
C++ 多线程与并发
java·jvm·c++
失去的青春---夕阳下的奔跑12 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光13 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩13 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up