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;
}
相关推荐
charlie11451419120 分钟前
通用GUI编程技术——Win32 原生编程实战(二十二)——GDI 位图操作:BitBlt、StretchBlt 与图像处理
c++·windows·学习·c·win32
Darkwanderor8 小时前
什么数据量适合用什么算法
c++·算法
超绝振刀怪8 小时前
【C++多态】
开发语言·c++
zc.ovo8 小时前
河北师范大学2026校赛题解(A,E,I)
c++·算法
py有趣8 小时前
力扣热门100题之环形链表
算法·leetcode·链表
py有趣8 小时前
力扣热门100题之回文链表
算法·leetcode·链表
学嵌入式的小杨同学9 小时前
STM32 进阶封神之路(三十九)FreeRTOS 临界区、挂起 / 删除、钩子函数、调度底层原理|从应用到内核深度解析
c++·stm32·单片机·嵌入式硬件·mcu·硬件架构·pcb
oioihoii9 小时前
Cursor根本无法调试C++
开发语言·c++
月落归舟10 小时前
帮你从算法的角度来认识二叉树---(二)
算法·二叉树