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,那么在加上次短路的条数. ...
随机推荐
- Linux关机和重启命令
shutdown shutdown [选项] 时间 选项: -c : 取消一个关机命令 -h : 关机 -r : 重启 [root@localhost ~]# date Tue Dec 6 21:06 ...
- 剑指offer五:
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. /* public class ListNode { int val; ListNode next = n ...
- window 配置wnmp(转下整理 ,全)
工具/原料 RunHiddenConsole.exe 下载地址:http://pan.baidu.com/share/link?shareid=100074&uk=822373947 方法 ...
- 利用CSS制作三角形
在我们看到类似于这样的图片时: 我们一般都会想,哎,这还不简单,用一张图片就可以了. 的确,用图片可以很轻松地做到.不过我们接下来要讨论的是: 如何用css也作出这样的效果. 首先,我们来定义一个 ...
- 跨站请求伪造 CSRF / XSRF<一:介绍>
跨站请求伪造(英语:Cross-site request forgery),也被称为 one-click attack 或者 session riding,通常缩写为 CSRF 或者 XSRF, 是一 ...
- gulp 插件
原文链接:http://www.mamicode.com/info-detail-517085.html gulp是什么? http://gulpjs.com/ 相信你会明白的! 与著名的构建工具gr ...
- Webpack、Browserify和Gulp
https://www.zhihu.com/question/37020798 https://www.zhihu.com/question/35479764
- C++输入cout与输出cin
输入和输出并不是C++语言中的正式组成成分.C和C++本身都没有为输入和输出提供专门的语句结构.输入输出不是由C++本身定义的,而是在编译系统提供的I/O库中定义的.C++的输出和输入是用" ...
- samba完美安装
感觉是一个相当强大的东西. Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件.它为局域网内的不同计算机之间提供文件及打印机等资源的共享服务.为客户机/服务器型协议,客户机通过该协议 ...
- java, listmap2json, fastjson
import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;impor ...