POJ 3463 有向图求次短路的长度及其方法数
题目大意:
希望求出走出最短路的方法总数,如果次短路只比最短路小1,那也是可取的
输出总的方法数
这里n个点,每个点有最短和次短两种长度
这里采取的是dijkstra的思想,相当于我们可以不断找到更新到的最短长度来更新其他长度,保证之前的所有可取的最短长度都已经更新的情况下,这样是除了第一个点的最短路为0已知,还需要更新2*n-1次,如果从一个点的位置出发更新了其他点,那么这个位置就不再作为可更新点~~这里都是暴力找最优的可更新的点~~不知道如何做到像普通的dijkstra那种log级别的找点~~
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define N 1005
#define M 10005
#define clr(a,b) memset(a,b,sizeof(a))
struct Edge{
int x,y,d,next;
Edge(int x=,int y=,int d=,int next=):x(x),y(y),d(d),next(next){}
}e[M<<];
int first[N] , tot , n , m , s , t;
void add_edge(int x,int y,int d)
{
e[tot] = Edge(x,y,d,first[x]);
first[x] = tot++;
}
int dis[N][] , cnt[N][] , vis[N][];
void dijkstra(int s , int t)
{
clr(dis,0x3f);clr(vis,);clr(cnt,);
dis[s][]=;cnt[s][]=;
for(int i=;i<*n;i++){
int a= , b= , curd=0x7fffffff;
for(int j=;j<=n;j++){
if(dis[j][]<curd && !vis[j][]) curd=dis[j][] , a=j,b=;
if(dis[j][]<curd && !vis[j][]) curd=dis[j][] , a=j,b=;
}
// cout<<a<<" "<<b<<" "<<curd<<endl;
vis[a][b]=;
for(int i=first[a];~i;i=e[i].next){
int v = e[i].y , nowd=curd+e[i].d;
if(nowd<dis[v][]){
dis[v][]=dis[v][];cnt[v][]=cnt[v][];
dis[v][]=nowd;cnt[v][]=cnt[a][b];
}
else if(nowd == dis[v][]){
cnt[v][]+=cnt[a][b];
}
else if(nowd <dis[v][]){
dis[v][]=nowd ;cnt[v][]=cnt[a][b];
}
else if(nowd==dis[v][]){
cnt[v][]+=cnt[a][b];
}
}
}
// cout<<cnt[t][0]<<" "<<cnt[t][1]<<endl;
if(dis[t][]- == dis[t][]) cnt[t][]+=cnt[t][];
printf("%d\n" , cnt[t][]);
}
int main()
{
// freopen("a.in" , "r" , stdin);
int T;
scanf("%d" , &T);
while(T--){
scanf("%d%d" , &n , &m);
clr(first,-);tot=;
for(int i=; i<m ; i++){
int x,y,d;
scanf("%d%d%d" , &x, &y , &d);
add_edge(x , y , d);
} scanf("%d%d" , &s , &t);
dijkstra(s,t);
} return ;
}
POJ 3463 有向图求次短路的长度及其方法数的更多相关文章
- COJ 0579 4020求次短路的长度
4020求次短路的长度 难度级别:C: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 在一个地图上共有N个路口(编号分别为1到N),R条道路( ...
- 一个n*n 的方格,要从左上角走到右下角,一次只能往右或往下走一步,求算法得出所有走动的方法数。
题目一:一个n*n 的方格,要从左上角走到右下角,一次只能往右或往下走一步,求算法得出所有走动的方法数. 分析:对于第(i,j)个格子,只有向右走一步到达或者向左走一步到达,dp(i,j) = d(i ...
- POJ 3463 Sightseeing 【最短路与次短路】
题目 Tour operator Your Personal Holiday organises guided bus trips across the Benelux. Every day the ...
- POJ 3463 Sightseeing (次短路经数)
Sightseeing Time Limit: 2000MS Memory Limit: 65536K Total Submissions:10005 Accepted: 3523 Descr ...
- hdu 3191 次短路的长度和个数
http://acm.hdu.edu.cn/showproblem.php?pid=3191 求次短路的长度和个数 相关分析在这里http://blog.csdn.net/u012774187/art ...
- POJ 1113 Wall 求凸包的两种方法
Wall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 31199 Accepted: 10521 Descriptio ...
- poj 3463/hdu 1688 求次短路和最短路个数
http://poj.org/problem?id=3463 http://acm.hdu.edu.cn/showproblem.php?pid=1688 求出最短路的条数比最短路大1的次短路的条数和 ...
- 【Dijkstra+邻接表求次短路】POJ Sightseeing 3463
Language: Default Sightseeing Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 7766 Ac ...
- POJ - 3463 Sightseeing 最短路计数+次短路计数
F - Sightseeing 传送门: POJ - 3463 分析 一句话题意:给你一个有向图,可能有重边,让你求从s到t最短路的条数,如果次短路的长度比最短路的长度多1,那么在加上次短路的条数. ...
随机推荐
- ip封包
I P封包 從一直以來討論至今﹐我們都不斷地接觸到“封包”這個詞﹐相信您也很有興趣想知道這個“封包”究竟是個什麼樣的東東吧﹗下面就讓我們一起看看一個IP封包究竟包含了那些內容. 擷取IP封包 如果您的 ...
- html5视屏背景注意事项。
在动手编码实现前,视频作为网页背景的有些问题我们要先考虑清楚: 并不是因为技术上可行你就可以任意使用:作为背景的视频内容必须能增强页面内容的感染力,而不是因为漂亮或技术上很酷就使用它. 作为背景的视频 ...
- TFS二次开发系列:八、TFS二次开发的数据统计以PBI、Bug、Sprint等为例(二)
上一篇文章我们编写了此例的DTO层,本文将数据访问层封装为逻辑层,提供给界面使用. 1.获取TFS Dto实例,并且可以获取项目集合,以及单独获取某个项目实体 public static TFSSer ...
- 如何让老Mac机支持USB安装Windows
一些老Mac机的用户想装Windows,却发现自己的系统上的Boot Camp Assistant(以下简称BCA)没有USB安装Windows的选项. 下面以我的MacBook Pro (13-in ...
- 单据UI代码开发
1.构造UI项目后,打开生成的UI项目代码,在Model文件下,如初始化一些字段的值 2.订单明细行中行号设置.订单基本操作按钮提示UFIDA.U9.Base.BaseBP.Agent.dll(代理) ...
- 简述Session 、Cookie、cache 区别
区别: 1.session是把数据保存在服务器上,每一个用户都有自己的session. 2.cookie是保存在客户端(也就是本机电脑). 3.cache是保存在服务器上,每个用户都可以访问的对象. ...
- HTML中使背景图片自适应浏览器大小
由于<body>标签的图片不能够拉伸, 解决办法: 1.图片不够大,又background属性不能拉伸图片: 2.只能用个div,把其z-index值设为负,并使这个div大小为整个bod ...
- SQL基础--序列
序列是一种数据库对象,用来自动产生一组唯一的序号:序列是一种共享式的对象,多个用户可以共同使用序列中的序号. 序列的创建语法 CREATE SEQUENCE sequencename [INCREME ...
- MFC编程入门之二十一(常用控件:编辑框Edit Control)
上一节讲了静态文本框,本节讲的是编辑框(Edit Control)同样是一种很常用的控件,我们可以在编辑框中输入并编辑文本.在前面加法计算器的例子中已经演示了编辑框的基本应用.下面具体讲解编辑框的使用 ...
- svn 版本控制
首先来下载和搭建SVN服务器. Subversion已经迁移到apache网站上了,下载地址: http://subversion.apache.org/packages.html windows操作 ...