首页 > 其他分享 >[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G

[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G

时间:2022-11-25 20:03:49浏览次数:78  
标签:Cow temp int res ids floyd include Relays


[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G

题目

[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G_最短路

思路

边数限制的最短路?bellman_ford可以拿来解决边数<=k的最短路,但这题是边数恰好为k,可以通过奇妙操作改成恰好经过k条边(但我不会)。
这里写倍增floyd解法(只是看着像floyd,但本质不一样)
原本floyd的dp为
[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G_算法_02
现在根据这题把dp改为
[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G_#include_03
状态转移,我们枚举中间点k(1~n)
[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G_线性代数_04
可以发现任意i到j的过程是独立的,并且具有结合律,那么我们可以用矩阵快速幂去加速。
对比普通floyd和本题的dp转移(类floyd)
普通floyd

void floyd(){
for(int k=1;k<=n;k++)
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
}

类floyd

for (int k = 1; k <= n; k ++ )
for (int i = 1; i <= n; i ++ )
for (int j = 1; j <= n; j ++ )
temp[i][j] = min(temp[i][j], a[i][k] + b[k][j]);

两者的区别是,普通floyd每次会用本次结果来自我更新,而类floyd只用上一次的结果来更新一次,这让边数变的可以控制。
这里去看acwing的​​​这篇题解​

代码

[边数限制最短路 倍增floyd 矩阵优化]Cow Relays G_离散化_05

#include <cstring>
#include <iostream>
#include <algorithm>
#include <map>

using namespace std;

const int N = 210;

int k, n, m, S, E;
int g[N][N];
int res[N][N];

void mul(int c[][N], int a[][N], int b[][N])
{
static int temp[N][N];
memset(temp, 0x3f, sizeof temp);
for (int k = 1; k <= n; k ++ )
for (int i = 1; i <= n; i ++ )
for (int j = 1; j <= n; j ++ )
temp[i][j] = min(temp[i][j], a[i][k] + b[k][j]);
memcpy(c, temp, sizeof temp);
}

void qmi()
{
memset(res, 0x3f, sizeof res);
for (int i = 1; i <= n; i ++ ) res[i][i] = 0;//经过0条边
while (k)
{
if (k & 1) mul(res, res, g); // res = res * g
mul(g, g, g); // g = g * g
k >>= 1;
}
}

int main()
{
cin >> k >> m >> S >> E;

memset(g, 0x3f, sizeof g);
map<int, int> ids;
if (!ids.count(S)) ids[S] = ++ n;//离散化
if (!ids.count(E)) ids[E] = ++ n;
S = ids[S], E = ids[E];

while (m -- )
{
int a, b, c;
cin >> c >> a >> b;
if (!ids.count(a)) ids[a] = ++ n;
if (!ids.count(b)) ids[b] = ++ n;
a = ids[a], b = ids[b];

g[a][b] = g[b][a] = min(g[a][b], c);
}

qmi();

cout << res[S][E] << endl;

return 0;
}


标签:Cow,temp,int,res,ids,floyd,include,Relays
From: https://blog.51cto.com/u_15891800/5887704

相关文章

  • PICOW避坑-I2C
    1.I2C扫描出的地址“错误”看代码中I2C地址是0x78H,结果扫描出来是0x3c——没有注意到它们是两倍关系。I2C.scan()扫描出来的确实是地址,只有7bit,比如0x3c:0111100XB;写......
  • SP11469 SUBSET - Balanced Cow Subsets Sol
    考虑枚举\(3^n\)种情况,用三进制数表示。对于每一位,\(0\)表示不放,\(1\)表示放入第一个集合,\(2\)表示放入第二个集合。这样显然会TLE。考虑meetinthemiddle。考......
  • [图论]floyd统计最小环个数
    使用floyd可以求解最小环问题.单纯需要求出最小环长度,方法显而易见最小环-OIWiki(oi-wiki.org)然而,如果需要统计最小环的个数,就比较麻烦.记\(cnt_{i,j}\)表示从\(i......
  • Floyd算法的关键点
    Floyd算法的代码很简单,就是三个for这个算法最重要的地方就是中转点的枚举for(intk=1;k<=n;k++)for(inti=1;i<=n;i++)for(intj=1;j<=n;j++)g[i][j]=max(g[i][j],g[i......
  • 数据结构 最短生成路径(BFS算法、Floyd(弗洛伊德)算法、Dijkstra算法)
    8.9、最短生成路径-BFS算法BFS算法只能处理无权图BFS算法的基本思想代码实现#include<stdio.h>#include<stdlib.h>#include<math.h>#defineMaxSize100#defin......
  • Til the Cows Come Home
    题目:题解:最短路模板#include<iostream>#include<cstdio>#include<cstdlib>#include<cstring>#include<cmath>#include<algorithm>#include<queue>#include<stack>#include<......
  • 【题解】洛谷P2946 [USACO09MAR]Cow Frisbee Team S
    这题乍一看是一个朴素的01背包问题,将所有方案的集合按照能力值的和来划分成1~m,然后把m当作体积,把n当作物品数,做一个01背包的代码。于是我兴冲冲地写了代码交上去,然后十组样......
  • 使用qcow2磁盘格式的文件作为Qemu根文件系统
    参考使用Qemu运行Ubuntu文件系统(1)qemu-img命令详解qemu-nbd简单操作操作创建qcow2格式文件qemu-imgcreate-fqcow2ubuntu22.qcow2100G挂载modprobenb......
  • KVM 动态调整 qcow2 硬盘
    动态扩容参考:https://cloud-atlas.readthedocs.io/zh_CN/latest/kvm/kvm_vdisk_live.html在宿主机器上使用qemu-imgresize命令调整磁盘大小,会提示不可操作#qemu-im......
  • P2971 [USACO10HOL]Cow Politics G
    题意一个树上每一个点都有一个组别,求相同组别的点对相差的最大距离。分析首先对于任意一个组别,深度最大的点一定在答案的点对里。证明假设答案的点对里没有深度最大......