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,那么在加上次短路的条数. ...
随机推荐
- JQ完成表格单元格顺序的上移下调
如有指教及疑问,欢迎留言 HTML代码 <table class="exampletable"> <thead> <tr> <th> ...
- Generate Time Data(普通日期主数据)
Note: While using this option you need to replicate the standard table into SAP HANA that is T005T, ...
- c# 无法加载 DLL xxxxxxxx找不到指定的模块。 (异常来自HRESULT:0x8007007E)。的一个解决方法
最近在做一个程序,想把某些功能用C++写成DLL供C#调用.但是无法如何都无法调用,提示"无法加载 DLL xxxxxxxx找不到指定的模块. (异常来自HRESULT:0x8007007E ...
- ECharts-图表回执组件
测试地址:http://echarts.baidu.com/doc/example.html
- 给ListBox每项加图标
先设置listBoxMsg.DrawMode = DrawMode.OwnerDrawFixed; private void listBoxMsg_DrawItem(object sender, Dr ...
- LSMW批处理工具操作手册
目录 1. 创建PROJECT 1 2.第一步:初始界面后点击执行出现如下对话框 3 3.第二步:维护源结构 8 4.第三步:Maintain Source Fields 9 4. ...
- node.js基础 1之 Querystring参数处理小利器
在处理查询字符串中很有用(⊙o⊙)哦~~~ querystring.stringify(obj,sign1,sign2)//将对象转化成url中query部分的形式 参数:1.要转化的对象 2.链接符 ...
- JAVA OO 第二章知识点
一.JAVA的基础语法 1.关键字 ①关键字:关键字用于定义该门语言,且这些单词对编译器用特殊的含义,而且不能作为标识符. 2.标识符 标识符:在JAVA中我们备选的单词,包括:类名.方法名.字段.变 ...
- Discuz! X3搬家后UCenter出现UCenter info: MySQL Query Error解决方案
Discuz! X3 X2.5论坛搬家后 登录UCenter出现报错:UCenter info: MySQL Query ErrorSQL:SELECT value FROM [Table]vars ...
- 关于easyui遇到的一些问题
一.TreeGrid在IE浏览器中不能刷新 在创建TreeGrid的时候将method: 'get' 改成 method: 'post' , 然后再$('#ProductGrid').treegrid ...