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,那么在加上次短路的条数. ...
随机推荐
- 百度-official
1.请描述html5新增的一些标签,描述这些标签的用法和语义 2.css属性position的属性值有哪些,描述它们的作用 3.常见的浏览器端的存储技术有哪些,以及它们的优缺点 4.程序定义如下: v ...
- Best 3D Modeling software under Ubuntu
Blender Blender is the best free and open source 3D modelling program out there by a long shot! The ...
- 求两条直线相交点 AS3代码
,); ,); ,); ,); var p:Point = new Point(); trace(checkPoint()) function checkPoint() { if (p1Start.x ...
- html 上传预览图片
直接上代码了 <!DOCTYPE html> <html><head lang="en"><meta http-equiv="C ...
- Linux C相关基础
系统求助 man 函数名 man 2 函数名 - 表示函数是系统调用函数 man 3 函数名 - 表示函数是C的库函数 eg:man fread man 2 w ...
- 【Extjs】large按钮,图片全部覆盖按钮
在网上找了一些办法,不太好用,还是该Extjs的样式来的最快... 将下列css加到Extjs所用页面. .x-btn-default-large-mc { padding-bottom:0px !i ...
- Linux新建用户并添加到sudo组
原文参考链接:https://www.douban.com/note/338488349/ 以在kali 下添加一个test用户为例: Step1#:添加新用户useradd -r -m -s /bi ...
- Tomcat7.0安装配置
很久没有通过博客对学习所得进行记录了. 现在将使用Tomcat的一些经验和心得写到这里,作为记录和备忘.如果有朋友看到,也请不吝赐教. 首先,我个人使用的是apache-tomcat-7.0.27你可 ...
- struts 头像上传
java代码: 1 package cn.itcast.nsfw.user.action; import java.io.File; import java.io.IOException; impor ...
- c++11的右值引用、移动语义
对于c++11来说移动语义是一个重要的概念,一直以来我对这个概念都似懂非懂.最近翻翻资料感觉突然开窍,因此记下.其实搞懂之后就会发现这个概念很简单,并无什么高深的地方. 先说说右值引用.右值一般指的是 ...