题目链接

/*
*题目大意:
*求出从i到j,刚好经过k条边的最短路;
*
*矩阵乘法的应用之一(国家队论文):
*矩阵乘法不满足交换律,矩阵乘法满足结合律;
*给定一个有向图,问从A点恰好走k步(允许重复经过边)到达B点的方案数mod p的值;
*把给定的图转为邻接矩阵,即A(i,j)=1当且仅当存在一条边i->j;
*令C=A*A,那么C(i,j)=ΣA(i,k)*A(k,j),实际上就等于从点i到点j恰好经过2条边的路径数(枚举k为中转点);
*类似地,C*A的第i行第j列就表示从i到j经过3条边的路径数;
*同理,如果要求经过k步的路径数,只需要二分求出A^k即可;
*
*算法思想:
*类似于快速幂的矩阵相乘的方法,只是把相乘部分改成floyd;
*基于动态规划:d[i][j][k],表示点i到j有2^k条路径的最短路;
*INF值很奇怪,各种数据都感觉不合适,换了很多次才过;
**/
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<queue>
#include<cstdio>
#include<climits>
#include<algorithm>
using namespace std; const int MAXN=222;
const int MAXM=1111;
//const int INF=0xfffffff;
const int INF=999999999; int f[MAXM];
int cnt;
int map[MAXN][MAXN];
int res[MAXN][MAXN],tmp[MAXN][MAXN];//res[i][j]表示i与j之间的最短路(之间有n条路),这个n是时刻变化的 int N,T,S,E;
void solve(int n)//就像快速幂的矩阵连乘,只是把相乘部分改成floyd
{
while(n)
{
if(n%2)//n为奇数时,n=2^a+2^a+b,这里补上b步,后面计算2*2^a步;
{
for(int i=1; i<=cnt; i++)
for(int j=1; j<=cnt; j++)
tmp[i][j]=INF; for(int k=1; k<=cnt; k++)
for(int i=1; i<=cnt; i++)
for(int j=1; j<=cnt; j++)
if(tmp[i][j]>res[i][k]+map[k][j])
tmp[i][j]=res[i][k]+map[k][j]; for(int i=1; i<=cnt; i++)
for(int j=1; j<=cnt; j++)
res[i][j]=tmp[i][j];
} for(int i=1; i<=cnt; i++)
for(int j=1; j<=cnt; j++)
tmp[i][j]=INF;
for(int k=1; k<=cnt; k++)
for(int i=1; i<=cnt; i++)
for(int j=1; j<=cnt; j++)
if(tmp[i][j]>map[i][k]+map[k][j])
tmp[i][j]=map[i][k]+map[k][j]; for(int i=1; i<=cnt; i++)
for(int j=1; j<=cnt; j++)
map[i][j]=tmp[i][j]; n=n/2;
}
return;
} int main()
{
//freopen("C:\\Users\\Administrator\\Desktop\\kd.txt","r",stdin);
while(~scanf("%d%d%d%d",&N,&T,&S,&E))
{
for(int i=0; i<=MAXN; i++)
{
for(int j=0; j<=MAXN; j++)
map[i][j]=INF,res[i][j]=INF;
res[i][i]=0;
}
memset(f,0,sizeof(f));
cnt=0;
int u,v,w;
for(int i=1; i<=T; i++)
{
scanf("%d%d%d",&w,&u,&v);
if(f[u]==0)
{
cnt++;
f[u]=cnt;
}
if(f[v]==0)
{
cnt++;
f[v]=cnt;
}
map[f[u]][f[v]]=w;
map[f[v]][f[u]]=w;
}
solve(N);
printf("%d\n",res[f[S]][f[E]]);
}
return 0;
}

图论专题训练1-D(K步最短路,矩阵连乘)的更多相关文章

  1. POJ --- 3613 (K步最短路+矩阵快速幂+floyd)

    Cow Relays   Description For their physical fitness program, N (2 ≤ N ≤ 1,000,000) cows have decided ...

  2. 专题训练——[kuangbin带你飞]最短路练习

    最短路练习 0. Til the Cows Come Home  POJ - 2387 完美的模板题 //#include<Windows.h> #include<iostream& ...

  3. luogu题解 P2886 【牛继电器Cow Relays】-经过K边最短路&矩阵

    题目链接: https://www.luogu.org/problemnew/show/P2886 Update 6.16 最近看了下<算法导论>,惊奇地发现在在介绍\(APSP\) \( ...

  4. poj3613Cow Relays——k边最短路(矩阵快速幂)

    题目:http://poj.org/problem?id=3613 题意就是求从起点到终点的一条恰好经过k条边的最短路: floyd+矩阵快速幂,矩阵中的第i行第j列表示从i到j的最短路,矩阵本身代表 ...

  5. DP专题训练之HDU 2955 Robberies

    打算专题训练下DP,做一道帖一道吧~~现在的代码风格完全变了~~大概是懒了.所以.将就着看吧~哈哈 Description The aspiring Roy the Robber has seen a ...

  6. dp专题训练

    ****************************************************************************************** 动态规划 专题训练 ...

  7. hdu 2157 从a点走到b点刚好k步的方案数是多少 (矩阵快速幂)

    n个点 m条路 询问T次 从a点走到b点刚好k步的方案数是多少 给定一个有向图,问从A点恰好走k步(允许重复经过边)到达B点的方案数mod p的值把 给定的图转为邻接矩阵,即A(i,j)=1当且仅当存 ...

  8. 经典矩阵快速幂之二-----hdu2157(走k步到

    题意:(中问题,题意很简单 思路:a走k步到b,其实就是A^k,ans.mat[a][b]就是答案. 其实就是离散的邻接矩阵那个P(不想证明,逃 #include<cstdio> #inc ...

  9. 正睿OI国庆DAY2:图论专题

    正睿OI国庆DAY2:图论专题 dfs/例题 判断无向图之间是否存在至少三条点不相交的简单路径 一个想法是最大流(后来说可以做,但是是多项式时间做法 旁边GavinZheng神仙在谈最小生成树 陈主力 ...

随机推荐

  1. for的用法

    第一次看到这么用,哈哈,就记下 for (var control = ["程", "陈", "是"]; control[0]; contro ...

  2. pyqt颜色字符

    from PyQt4.QtGui import QPlainTextEdit, QWidget, QVBoxLayout, QApplication, \ QFileDialog, QMessageB ...

  3. Highcharts 点击反选

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  4. (转)iOS7界面设计规范(8) - UI基础 - 术语和措辞

    讨厌周一,讨厌一周.今天中午交互组聚餐,却很开心:大家都是很厉害的人,你可以感到他们身上的能量,可以感到有些什么东西正在推着自己尽力向前走.这是一种很健康的状态,同时也很难得,自然越发需要珍惜.从无到 ...

  5. (转)iOS Wow体验 - 第二章 - iOS用户体验解析(2)

    本文是<iOS Wow Factor:Apps and UX Design Techniques for iPhone and iPad>第二章译文精选的第二部分,其余章节将陆续放出.上一 ...

  6. 关于ionic的一些坑(3)

    (1)对于页面中的input之类的输入框,取值的时候一般采用的是$scope.model=””的方式来取得input输入框的值,然后进行操作,但实际上在ionic里面是取不到的,取值之前必须先把inp ...

  7. Android + eclipse +ADT安装完全教程

    最近几天没事做,网上看来看去突然就想弄个android来学学...  首先,是要下载android SDK,在http://developer.android.com/sdk/index.html这个 ...

  8. PHP 生成.csv 文件并下载到浏览器

    近期做了一个项目须要把订单的信息显示出来.而且可以把相关信息放到一个.csv 文件里,下载到浏览器.首先我要说明的是.csv 文件,PHP 有专门的函数去解析该类型的文件,相关函数大家可以去官网查看. ...

  9. 华为Oj 找出字符串第一个出现一次的字符

    #include <stdio.h> #include <string.h> char firstSingle(char *str) { int hash[255]={0}; ...

  10. VC 串口通信类

    为了节省时间,我就贴出来吧 头文件 SerialPort.h /******************************************************************** ...