最短路 + 矩阵快速幂

我们可以改进矩阵快速幂,使得它适合本题

用图的邻接矩阵和快速幂实现

注意 dis[i][i] 不能置为 0

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <cstdlib>
using namespace std;
struct edge{
int u, v, dis;
}e[10000];
int n, m, p, ss, tt;
void work() {
int sub[10005];
for(int i = 1; i <= m; i++) {
cin >> e[i].dis >> e[i].u >> e[i].v;
sub[++n] = e[i].u;
sub[++n] = e[i].v;
}
sort(sub + 1, sub + n + 1);
n = unique(sub + 1, sub + n + 1) - sub - 1;
for(int i = 1; i <= m; i++) {
e[i].u = lower_bound(sub + 1, sub + n + 1, e[i].u) - sub;
e[i].v = lower_bound(sub + 1, sub + n + 1, e[i].v) - sub;
}
ss = lower_bound(sub + 1, sub + n + 1, ss) - sub;
tt = lower_bound(sub + 1, sub + n + 1, tt) - sub;
}
struct Matrix{
int num[205][205];
void clear() {
memset(num, 0x3f, sizeof(num));
}
void unit() {
memset(num, 0, sizeof(num));
for(int i = 0; i < 205; i++) num[i][i] = 1;
}
Matrix operator * (const Matrix & b) {
Matrix ans;
ans.clear();
for(int i = 1; i <= n; i++) {
for(int j = 1; j <= n; j++) {
for(int k = 1; k <= n; k++) {
ans.num[i][j] = min(ans.num[i][j], num[i][k] + b.num[k][j]);
}
}
}
return ans;
}
void print() {
for(int i = 1; i <= n; i++) {
for(int j = 1; j <= n; j++) {
printf("%d ", num[i][j]);
}
printf("\n");
}
}
Matrix operator ^ (int k) {
Matrix ans;
k--;
ans = (*this);
while(k) {
if(k & 1) ans = ans * (*this);
(*this) = (*this) * (*this);
k >>= 1;
}
return ans;
}
};
int main() {
cin >> p >> m >> ss >> tt;
work();
Matrix a;
a.clear();
//for(int i = 1; i <= n; i++) a.num[i][i] = 0;
for(int i = 1; i <= m; i++) {
a.num[e[i].u][e[i].v] = a.num[e[i].v][e[i].u] = min(e[i].dis, a.num[e[i].u][e[i].v]);
}
a = a ^ p;
//a.print();
printf("%d\n", a.num[ss][tt]);
return 0;
}

最新文章

  1. 思维导图MindManager的文件格式与例图
  2. 【转载】kafka的工作原理
  3. C语言 日常小结
  4. 20145208 《Java程序设计》第8周学习总结
  5. JUC回顾之-可重入的互斥锁ReentrantLock
  6. [Java] JVM 在执行 main 方法前的行为
  7. Arduino Micro USB库
  8. 2208: [Jsoi2010]连通数
  9. 微信小程序异步请求问题
  10. android使用smack实现简单登录功能
  11. poj1177 矩形周长并
  12. C++中int与string的相互转换【转】
  13. makefile 使用 Tricks
  14. Spark中的IsNotNull函数怎么用
  15. aarch64_m2
  16. 《LAMP系统工程师实用教程》读书笔记(一)- linux常用命令
  17. php -- PHP实现点击a标签的href做链接时,直接保存文件(任何类型),而不是通过浏览器直接打开下载的文件
  18. Python 读取图像文件的性能对比
  19. 树(Tree,UVA 548)
  20. PHP使用前的了解

热门文章

  1. J.U.C知识点梳理
  2. inner join 和 left join 的区别
  3. 零拷贝详解 Java NIO学习笔记四(零拷贝详解)
  4. Linux基础学习-用户的创建修改删除
  5. Voyager的安装及配置文件
  6. Python基础——模块与包
  7. 用Python设置matplotlib.plot的坐标轴刻度间隔以及刻度范围
  8. LeetCode(260) Single Number III
  9. 学习ucosii要用到的几本书
  10. uncaught exception &#39;NSInternalInconsistencyException, reason:[UITableViewController loadView] loaded the &quot;Controller&quot; nib but didn&#39;t get a UITableView