博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
luogu 1608 路径统计--最短路计数
阅读量:5039 次
发布时间:2019-06-12

本文共 934 字,大约阅读时间需要 3 分钟。

题意相似,建议还没做的先去做一下。

当你看完上一题,就已经对最短路计数大体有一个思想了,但是本题中没有说不保证没有重边和自环,那么开一个map数组记录一下就好了,自环的话我使用spfa解决的,那么我们就可以按部就班的写最短路计数了。

不过有个bug源自于spfa算法,见下图。

当你按spfa的手动模拟的时候你会发现到达5号点的路径有3条,但是其真实路径只有两条,我们应该在处理完每一个点后将这个点的路径数量清零(在其更新完其他点以后),避免二次计算的时候再次累加。

#include
#include
#include
#include
#include
using namespace std;int i,j,m,n;int head[2001];int us[2001];int t[2001];int dis[2001];int a[2001][2001];queue
q;int r(){ int aans=0; char ch=getchar(); while(ch<'0'||ch>'9') ch=getchar(); while(ch>='0'&&ch<='9') { aans*=10; aans+=ch-'0'; ch=getchar(); } return aans;}int spfa(int x){ q.push(x);dis[x]=0;t[x]=1; while(!q.empty()) { int x=q.front(); q.pop(); us[x]=0; if(x==n) continue; for(i=1;i<=n;i++) { if(dis[x]+a[x][i]==dis[i]) t[i]+=t[x]; if(dis[x]+a[x][i]

 

转载于:https://www.cnblogs.com/rmy020718/p/9440589.html

你可能感兴趣的文章
mysql忘记root密码
查看>>
apache服务器中设置目录不可访问
查看>>
嵌入式Linux驱动学习之路(十)字符设备驱动-my_led
查看>>
【NOIP模拟】密码
查看>>
java容器---------手工实现Linkedlist 链表
查看>>
three.js 性能优化的几种方法
查看>>
《梦断代码》读书笔记(三)
查看>>
FreeMarker解析json数据
查看>>
Java8 Lambda表达应用 -- 单线程游戏server+异步数据库操作
查看>>
次序+“选择不重复的记录”(3)——最大记录
查看>>
Codeforces 450 C. Jzzhu and Chocolate
查看>>
[Unity3D]Unity3D游戏开发MatchTarget的作用攀登效果实现
查看>>
ACdream 1115 Salmon And Cat (找规律&amp;&amp;打表)
查看>>
JSON、JSONP、Ajax的区别
查看>>
AngularJS学习篇(一)
查看>>
【转载】 IP实时传输协议RTP/RTCP详解
查看>>
关于Xshell无法连接centos6.4的问题
查看>>
Linux系统的数据写入机制--延迟写入
查看>>
css3动画——基本准则
查看>>
javaweb常识
查看>>