题目大意:

给定单向图的n m 为点数和单向边数

接下来m行给定 u v w 为边的起点终点和长度

给定q 为询问个数

接下来q行给定 x y k 求从x到y至少经过k条边的最短路长度

https://blog.csdn.net/qkoqhh/article/details/81301910

设 d[ i ][ j ][ k ] 为从i到j走至少k条边的最短路长度

设 f[ i ][ j ][ k ] 为从i到j恰好走k*100条边的最短路长度

那么至少走K条边的话

若 K>=100 有 f[ i ][ j ][ K/100 ] + d[ i ][ j ][ K%100 ]

若 K%100==0 有 f[ i ][ j ][ K/100 ]

若 K<100 有 d[ i ][ j ][ K ]

最小值就是至少走K条边的最短路

#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define INF 0x3f3f3f3f
#define mem(i,j) memset(i,j,sizeof(i))
#define inc(i,l,r) for(int i=l;i<=r;i++)
#define dec(i,r,l) for(int i=r;i>=l;i--)
const int N=+;
const int M=1e4+;
int n, m;
int d[N][N][], f[N][N][];
int main()
{
int _; scanf("%d",&_);
while(_--) {
scanf("%d%d",&n,&m);
inc(i,,n)inc(j,,n) d[i][j][]=INF;
while(m--) {
int u,v,w; scanf("%d%d%d",&u,&v,&w);
d[u][v][]=min(d[u][v][],w); // 更新至少1条边的答案
}
inc(i,,n)inc(j,,n) d[i][j][]=d[i][j][];
// 至少0条边的答案应和至少1条相同
inc(i,,n) d[i][i][]=;
// 点到本身的距离至少0条边答案肯定为0
inc(k,,) {
inc(i,,n)inc(j,,n) d[i][j][k]=INF;
inc(p,,n)inc(i,,n)inc(j,,n) // Floyd
d[i][j][k]=min(d[i][j][k],d[i][p][k-]+d[p][j][]);
}
inc(i,,n)inc(j,,n) f[i][j][]=d[i][j][];
// 按100条边(求了150条)分块应该够了
inc(k,,) {
inc(i,,n)inc(j,,n) f[i][j][k]=INF;
inc(p,,n)inc(i,,n)inc(j,,n) // Floyd
f[i][j][k]=min(f[i][j][k],f[i][p][k-]+f[p][j][]);
}
dec(k,,)
inc(i,,n)inc(j,,n)
d[i][j][k]=min(d[i][j][k],d[i][j][k+]);
// 至少k条边的答案 如果k+1的答案更优 同样可以更新
int q; scanf("%d",&q);
while(q--) {
int u,v,k; scanf("%d%d%d",&u,&v,&k);
int ans=INF;
if(k>) {
inc(p,,n)
ans=min(ans,f[u][p][k/]+d[p][v][k%]);
}
if(k%==) ans=min(ans,f[u][v][k/]);
if(k<=) ans=min(ans,d[u][v][k]);
if(ans==INF) printf("-1\n");
else printf("%d\n",ans);
}
} return ;
}

hdu6331 /// Floyd+分块DP的更多相关文章

  1. Codeforces Round #278 (Div. 1) D - Conveyor Belts 分块+dp

    D - Conveyor Belts 思路:分块dp, 对于修改将对应的块再dp一次. #include<bits/stdc++.h> #define LL long long #defi ...

  2. ACM: HDU 5418 Victor and World - Floyd算法+dp状态压缩

    HDU 5418 Victor and World Time Limit:2000MS     Memory Limit:131072KB     64bit IO Format:%I64d & ...

  3. AOJ 2200 Mr. Rito Post Office(Floyd+单调DP)

    [题目链接] http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=2200 [题目大意] 一张图中有陆路和水路,水路必须要有船才能走,当船 ...

  4. CF1129D Isolation(分块+DP)

    一个很显然的DP方程式:f[i]=Σf[j],其中j<i且在[j+1,i]中出现1次的数不超过k个 乍一看挺神仙的,只会O(n^2),就是对于每个位置从后向前扫一遍,边扫边统计出现1次的数的个数 ...

  5. LOJ #2802. 「CCC 2018」平衡树(整除分块 + dp)

    题面 LOJ #2802. 「CCC 2018」平衡树 题面有点难看...请认真阅读理解题意. 转化后就是,给你一个数 \(N\) ,每次选择一个 \(k \in [2, N]\) 将 \(N\) 变 ...

  6. [NOIP2016 D1T3]换教室 【floyd+概率dp】

    题目描述 对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程. 在可以选择的课程中,有 2n2n 节课程安排在 nn 个时间段上.在第 ii(1 \leq i \leq n1≤ ...

  7. POJ3311Hie with the Pie(floyd传递+DP,状态压缩)

    问题 The Pizazz Pizzeria prides itself in delivering pizzas to its customers as fast as possible. Unfo ...

  8. [CSP-S模拟测试]:旅行计划(分块+DP)

    题目传送门(内部题83) 输入格式 第一行两个整数$n,m$ 接下来$m$行,每行三个整数,$u,v,w$,表示从$u$到$v$有一条权值为$w$的边 接下来一行有一个整数$q$,表示$q$天 接下来 ...

  9. bzoj4720 / P1850 换教室(Floyd+期望dp)

    P1850 换教室 先用Floyd把最短路处理一遍,接下来就是重头戏了 用 f [ i ][ j ][ 0/1 ] 表示在第 i 个时间段,发出了 j 次申请(注意不一定成功),并且在这个时间段是否( ...

随机推荐

  1. Linux NIO 系列(04-2) poll

    目录 一.select 和 poll 比较 二.poll API 附1:linux 每个进程IO限制 附2:poll 网络编程 Linux NIO 系列(04-2) poll Netty 系列目录(h ...

  2. Python 常见报错类型

    一.TypeError:类型错误,对象用来表示值的类型非预期类型时发生的错误 错误例子: age=18 print(‘我的年龄是’+age) 报错信息:TypeError: can only conc ...

  3. jsp struts2导入excel并且存储到数据库中

    开发中遇到一个问题: 需要从外部导入excel,拿到其中的数据然后保存到数据库中. 1.先在jsp端使用input进行上传: <form action="storeOBDexcel&q ...

  4. 从一个url地址到最终页面渲染完成,发生了什么?

    从一个url地址到最终页面渲染完成,发生了什么? 1.DNS 解析 : 将域名地址解析为IP地址 浏览器DNS缓存 系统DNS缓存 路由器DNS缓存 网络运营商DNS缓存 递归搜索: www.baid ...

  5. Javascript高级程序设计--读书笔记之Array类型

    1.数组的lenght属性 数组的lenght属性很有特点---他不是只读的,可以同过修改这个属性来向数组的末尾添值加或删除值, 删除值 var color = ["red", & ...

  6. 带你看懂LayoutInflater中inflate方法

    关于inflate问题,我想很多人多多少少都了解一点,网上也有很多关于这方面介绍的文章,但是枯燥的理论或者翻译让很多小伙伴看完之后还是一脸懵逼,so,我今天想通过三个案例来让小伙伴彻底的搞清楚这个东东 ...

  7. Linux运行jar包

    要运行java的项目需要先将项目打包成war包或者jar包,打包成war包需要将war包部署到tomcat服务器上才能运行.而打包成jar包可以直接使用java命令执行. 在linux系统中运行jar ...

  8. django里面跨域CORS的设置

    安装 pip install django-cors-headers 添加应用 在settings里面配置 INSTALLED_APPS = ( ... 'corsheaders', ... ) 中间 ...

  9. mongoose 常用数据库操作 删除

    删除 Model.remove(conditions, [callback]) try.js var User = require("./user.js"); function d ...

  10. 代理端口转发工具rinetd

    转载: https://my.oschina.net/wuweixiang/blog/2983280 rinetd 前言 iptables 的功能当然强大,但理解与设置却有点抽象,便通过google认 ...