题目链接

/*
*题目大意:
*求出从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. Java Web----Java Web的数据库操作(一)

    Java Web的数据库操作 一.JDBC技术 1.JDBC简介 JDBC是Java程序与数据库系统通信的标准API,它定义在JDK的API中,通过JDBC技术,Java程序可以非常方便地与各种数据库 ...

  2. phpcms:四、尾部包含

    四.尾部包含1.包含尾部文件:{template "content","footer"}2.栏目列表调用(关于我们| 联系方式| 版权声明| 招聘信息|):{p ...

  3. phpcms:一、安装及新建模板

    1.复制D:\WWW\phpcms\phpcms\templates\目录下的default文件粘贴在当前目录下,并重命名为新模板名字(youpinzhiyuan2012) 2.打开D:\WWW\ph ...

  4. poj 2251 Dungeon Master(bfs)

    Description You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is co ...

  5. poj 1328 Radar Installation(贪心)

    Description Assume the coasting is an infinite straight line. Land is in one side of coasting, sea i ...

  6. 为MyEclipse加入自己定义凝视

    非常多时候我们默认的MyEclipse的类凝视是这种,例如以下图 能够通过改动MyEclipse的凝视规则来改变,不但能够改动类的.还能够改动字段.方法等凝视规则,操作方法例如以下 1.针对方法的凝视 ...

  7. web请求的处理流程

    web请求的处理流程如下: 1.客户发起请求到服务器网卡:2.服务器网卡接受到请求后转交给内核处理:3.内核根据请求对应的套接字,将请求交给工作在用户空间的Web服务器进程4.Web服务器进程根据用户 ...

  8. 让qq图标在自己的网站上显示方法

    代码如下: <div id="xixi" onmouseover="toBig()" style="top: 260px; left: 5px; ...

  9. IIS 7管理API——Microsoft.Web.Administration介绍

    原文:http://www.cnblogs.com/dflying/archive/2006/04/17/377276.html 本文翻译整理自Carlos Aguilar Mares的blog文章: ...

  10. java递归删除指定目录下的文件和文件夹

    public static boolean deleteFolder(String delDir) { File delFolder = new File(delDir); File[] delFil ...