【题目链接】

【题目概括】

对给定\(K\),起点\(1\)到终点\(n\)中对长度为\([L,L+K]\)的路径计数。

\(L\)为\(1\)到\(n\)的最短路长度。

【思路要点】

  • 考虑\(DP\),定义\(dp[i][j]\)表示从\(i\)点到终点\(n\)的距离比原来的最短距离长了\(j\)的方案数。
  • 那么考虑转移,\(dp[u][j]=\sum dp[v][j-g]\),其中\(g=dis[v]+w(i,j)-dis[u]\)。

【代码】

#include <bits/stdc++.h>

#define inf 0x3f3f3f3f

using namespace std;

const int N = 2e5 + 5;

struct _edge {
    int to, nt, w;
} E1[N], E2[N];

int H1[N], H2[N], dis[N];
int edgeCnt1, edgeCnt2;
bool vis[N];
bool ban[N][55];
int dp[N][55];
int n, m, k, MOD;

void addEdge1(int u, int v, int w) {
    E1[++edgeCnt1] = (_edge){v, H1[u], w};
    H1[u] = edgeCnt1;
}

void addEdge2(int u, int v, int w) {
    E2[++edgeCnt2] = (_edge){v, H2[u], w};
    H2[u] = edgeCnt2;
}

void init() {
    edgeCnt1 = edgeCnt2 = 0;
    for (int i = 1; i <= n; i++)
        H1[i] = H2[i] = 0;
    for (int i = 1; i <= n; i++)
        for (int j = 0; j <= k; j++)
            dp[i][j] = -1, ban[i][j] = 0;
}

void spfa(int s) {
    for (int i = 1; i <= n; i++)
        dis[i] = inf, vis[i] = 0;
    queue<int> q;
    q.push(s);
    vis[s] = 1;
    dis[s] = 0;
    while (!q.empty()) {
        int u = q.front();
        q.pop();
        vis[u] = 0;
        for (int e = H2[u]; e; e = E2[e].nt) {
            int v = E2[e].to;
            if (dis[v] > dis[u] + E2[e].w) {
                dis[v] = dis[u] + E2[e].w;
                if (!vis[v]) {
                    q.push(v);
                    vis[v] = 1;
                }
            }
        }
    }
}

int dfs(int u, int k) {
    if (k < 0)
        return 0;
    else if (ban[u][k])
        return -1;
    else if (dp[u][k] != -1)
        return dp[u][k];
    ban[u][k] = 1;
    dp[u][k] = 0;
    if (u == n)
        dp[u][k]++;
    for (int e = H1[u]; e; e = E1[e].nt) {
        int v = E1[e].to;
        if (dis[v] == inf)
            continue;
        int g = dis[v] + E1[e].w - dis[u];
        int res = dfs(v, k - g);
        if (res == -1)
            return -1;
        dp[u][k] = (dp[u][k] + res) % MOD;
    }
    ban[u][k] = 0;
    return dp[u][k];
}

int main() {
    int T; scanf("%d", &T);
    while (T--) {
        scanf("%d %d %d %d", &n, &m, &k, &MOD);
        init();
        for (int i = 1; i <= m; i++) {
            int u, v, w; scanf("%d %d %d", &u, &v, &w);
            addEdge1(u, v, w), addEdge2(v, u, w);
        }
        spfa(n);
        int ans = dfs(1, k);
        printf("%d\n", ans);
    }
    return 0;
}

【LOJ2316】「NOIP2017」逛公园的更多相关文章

  1. LOJ2316. 「NOIP2017」逛公园【DP】【最短路】【思维】

    LINK 思路 因为我想到的根本不是网上的普遍做法 所以常数出奇的大,而且做法极其暴力 可以形容是带优化的大模拟 进入正题: 首先一个很显然的思路是如果在合法的路径网络里面存在零环是有无数组解的 然后 ...

  2. 「NOIP2017」逛公园

    传送门 Luogu 解题思路 考虑 \(\text{DP}\). 设 \(f[u][k]\) 表示从 \(u\) 到 \(n\) 走过不超过 \(Mindis(u, n) + k\) 距离的方案数. ...

  3. [luogu P3953] [noip2017 d1t3] 逛公园

    [luogu P3953] [noip2017 d1t3] 逛公园 题目描述 策策同学特别喜欢逛公园.公园可以看成一张$N$个点$M$条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,$N ...

  4. 「WC2013」糖果公园

    「WC2013」糖果公园 传送门 树上带修莫队板子题. 看懂题意后就是板子题了. 参考代码: #include <algorithm> #include <cstdio> #i ...

  5. 「NOIP2017」宝藏

    「NOIP2017」宝藏 题解 博客阅读效果更佳 又到了一年一度NOIPCSP-S 赛前复习做真题的时间 于是就遇上了这道题 首先观察数据范围 \(1 \le n \le 12\) ,那么极大可能性是 ...

  6. 逛公园「NOIP2017」最短路+DP

    大家好我叫蒟蒻,这是我的第一篇信竞题解blog [题目描述] 策策同学特别喜欢逛公园. 公园可以看成一张 \(N\) 个点 \(M\) 条边构成的有向图,且没有自环和重边.其中 \(1\) 号点是公园 ...

  7. 【NOIP2017】逛公园 拆点最短路+拓扑(记忆化搜索

    题目描述 策策同学特别喜欢逛公园.公园可以看成一张N个点M条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,N号点是公园的出口,每条边有一个非负权值, 代表策策经过这条边所要花的时间. 策 ...

  8. 【NOIP2017】逛公园(最短路图,拓扑排序,计数DP)

    题意: 策策同学特别喜欢逛公园. 公园可以看成一张 N 个点 M 条边构成的有向图,且没有自环和重边.其中 1 号点是公园的入口, N 号点是公园的出口,每条边有一个非负权值,代表策策经过这条边所要花 ...

  9. NOIP2017:逛公园

    Sol 发现\(NOIP2017\)还没\(AK\)??? 赶紧改 考场上明明打出了\(DP\),没时间了,没判环,重点是没初始化数组,爆\(0\) \(TAT\) 先最短路,然后\(f[i][j]\ ...

随机推荐

  1. 从零开始,SpreadJS 新人学习笔记

    Hello,大家好,我是Fiona,从事前端开发工作,我十分热爱我的工作和一直默默栽培我的老板(这段请加粗). 前不久,接到老板的安排: 说实话,接到这个需求,我整个人的状态是这样的: 但是,我不能辜 ...

  2. 什么是云数据库RDS PostgreSQL 版

    PostgreSQL被业界誉为“最先进的开源数据库”,面向企业复杂SQL处理的OLTP在线事务处理场景,支持NoSQL数据类型(JSON/XML/hstore).支持GIS地理信息处理. 优点 NoS ...

  3. thinkphp6下无法获取header头中的Authorization(apache版)

    今天遇到在thinkphp框架中获取不到header头里边的 Authorization ,后来在.htaccess里面加多一项解决,记录下: <IfModule mod_rewrite.c&g ...

  4. Proxy.newInstance与InvocationHandler的使用示例

    先定义一个接口,根据代理模式的原理,被代理类与代理类都要实现它. public interface Person { void eat(); } 再写一个实际执行任务的类(被代理类): public ...

  5. 4G漏洞

    4G VoLTE漏洞:可致用户地理位置和其它个人信息泄露 2017-08-05 LBS 首先要了解下,什么是VoLTE. VoLTE为英文Voice Over LTE的缩写,直译就是音频通过LTE网络 ...

  6. VIM简单操作

    ngg就跳转到第n行行首,G就到结尾 0光标移到当前行行首 $光标移到当前行行末 fx搜索当前行中下一个出现x的地方 yy复制当前行 nyy复制当前行到n-1行 dd删除当前行 ndd删除当前行到n- ...

  7. FTP部署与使用

    1.1 环境检查 [root@www ~]# cat /etc/redhat-release #系统版本,6系列等区别不大,都可以 CentOS Linux release 7.5.1804 (Cor ...

  8. Centos的yum源更换为阿里云源

    1.备份 # mv /etc/yum.repos.d/CentOS-Base.repo # /etc/yum.repos.d/CentOS-Base.repo.backup 2.下载新的CentOS- ...

  9. glsl:error C1105: cannot call a non-function

    今天写的shader编译过程中报了这个错误,而且错误行数是0.原因怎么找也找不到.后来发现原来是normalize方法写成了了normal正好和函数的形参名字一样. 特地记录一下.

  10. lightinthebox头部分类菜单下拉导航,使鼠标移到See All Categories就显示下拉菜单

    lightinthebox头部分类菜单下拉导航,使鼠标移到See All Categories就显示下拉菜单 打开includes\templates\lightinthebox\common\tpl ...