/*
 *题目大意:
 *在一个有向图中,求从s到t两个点之间的最短路和比最短路长1的次短路的条数之和;
 *
 *算法思想:
 *用A*求第K短路,目测会超时,直接在dijkstra算法上求次短路;
 *将dist数组开成二维的,即dist[v][2],第二维分别用于记录最短路和次短路;
 *再用一个cnt二维数组分别记录最短路和次短路的条数;
 *每次更新路径的条数时,不能直接加1,,应该加上cnt[u][k],k为次短路径或者最短路径的标记;
 *图有重边,不能用邻接矩阵存储;
 *不知道为什么,题目上说的是N and M, separated by a single space, with 2≤N≤1000 and 1 ≤ M ≤ 10000;
 *而我的代码硬是把N开成1W了才过,求解释,RE了无数次,擦;
**/ 
#include<iostream> 
#include<cstdio> 
#include<cstring> 
#include<string> 
#include<algorithm> 
using namespace std; 
   
const int N=; 
const int M=; 
const int INF=0xffffff; 
   
struct node 

    int to; 
    int w; 
    int next; 
}; 
   
node edge[N]; 
int head[N]; 
   
int dist[N][],cnt[N][]; 
bool vis[N][]; 
int n,m,s,t,edges; 
   
void addedge(int u,int v,int w) 

    edge[edges].w=w; 
    edge[edges].to=v; 
    edge[edges].next=head[u]; 
    head[u]=edges++; 

   
int dijkstra() 

    int k; 
    for(int i=; i<=n; i++) 
    { 
        dist[i][]=dist[i][]=INF; 
        vis[i][]=vis[i][]=; 
        cnt[i][]=cnt[i][]=; 
    } 
    cnt[s][]=,dist[s][]=; 
   
    for(int i=; i<=n*; i++) 
    { 
        int u=-; 
        int min_dist=INF; 
        for(int j=; j<=n; j++) 
            for(int flag=; flag<; flag++) 
                if(!vis[j][flag]&&dist[j][flag]<min_dist) 
                { 
                    min_dist=dist[j][flag]; 
                    u=j; 
                    k=flag; 
                } 
        if(u==-) 
            break; 
        vis[u][k]=true; 
        for(int e=head[u]; e!=-; e=edge[e].next) 
        { 
            int j=edge[e].to; 
            int tmp=dist[u][k]+edge[e].w; 
   
            if(tmp<dist[j][])//tmp小于最短路径长: 
            { 
                dist[j][]=dist[j][];//次短路径长 
                cnt[j][]=cnt[j][];//次短路径计数 
                dist[j][]=tmp;//最短路径长 
                cnt[j][]=cnt[u][k];//最短路径计数 
            } 
   
            else if(tmp==dist[j][])//tmp等于最短路径长: 
            { 
                cnt[j][]+=cnt[u][k];//最短路径计数 
            } 
   
            else if(tmp<dist[j][])//tmp大于最短路径长且小于次短路径长: 
            { 
                dist[j][]=tmp;//次短路径长 
                cnt[j][]=cnt[u][k];//次短路径计数 
            } 
   
            else if(tmp==dist[j][])//tmp等于次短路径长: 
            { 
                cnt[j][]+=cnt[u][k];//次短路径计数 
            } 
        } 
    } 
   
    int res=cnt[t][]; 
    if(dist[t][]+==dist[t][])//判断最短路和次短路是否相差1 
        res+=cnt[t][]; 
    return res; 

   
int main() 

    //freopen("C:\\Users\\Administrator\\Desktop\\kd.txt","r",stdin); 
    int tcase; 
    scanf("%d",&tcase); 
    while(tcase--) 
    { 
        edges=; 
        scanf("%d%d",&n,&m); 
        memset(head,-,sizeof(head)); 
        int u,v,w; 
        for(int i=; i<m; i++) 
        { 
            scanf("%d%d%d",&u,&v,&w); 
            addedge(u,v,w); 
        } 
        scanf("%d%d",&s,&t); 
        printf("%d\n",dijkstra()); 
    } 
    return ; 

最短路和次短路问题,dijkstra算法的更多相关文章

  1. 最短路:我的理解--Dijkstra算法

    最短路径:Dijkstra算法 用来计算从一个点到其他所有点的最短路径的算法,是一种单源最短路径算法.也就是说,只能计算起点只有一个的情况. Dijkstra的时间复杂度是O (N2),它不能处理存在 ...

  2. 最短路模板(Dijkstra & Dijkstra算法+堆优化 & bellman_ford & 单源最短路SPFA)

    关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ...

  3. ACM: HDU 2544 最短路-Dijkstra算法

    HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descrip ...

  4. [ACM_图论] Domino Effect (POJ1135 Dijkstra算法 SSSP 单源最短路算法 中等 模板)

    Description Did you know that you can use domino bones for other things besides playing Dominoes? Ta ...

  5. 单源最短路Dijkstra算法——matlab实现

    迪杰斯特拉(Dijkstra)算法是典型最短路径算法,用于计算一个节点到其他节点的最短路径. 它的主要特点是以起始点为中心向外层层扩展(广度优先搜索思想),直到扩展到终点为止. 基本思想 通过Dijk ...

  6. hdu2544 最短路 Dijkstra算法

    最短路(Dijkstra算法模板题) Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  7. 最短路(hdu2544)Dijkstra算法二

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  8. (转)最短路算法--Dijkstra算法

    转自:http://blog.51cto.com/ahalei/1387799         上周我们介绍了神奇的只有五行的Floyd最短路算法,它可以方便的求得任意两点的最短路径,这称为“多源最短 ...

  9. 单源最短路:Dijkstra算法 及 关于负权的讨论

    描述: 对于图(有向无向都适用),求某一点到其他任一点的最短路径(不能有负权边). 操作: 1. 初始化: 一个节点大小的数组dist[n] 源点的距离初始化为0,与源点直接相连的初始化为其权重,其他 ...

随机推荐

  1. 如何让局域网内的其他电脑访问本机的mysql

    测试电脑:本机ip是125.216.250.67  其他电脑 125.216.250.68 第一步:先用其他电脑ping本机,看能否ping通 如上图即为成功ping通了 第二步:开放mysql的全向 ...

  2. php如何上传txt文件,并且读取txt文件

    1.创建目录如下

  3. js把时间戳转换为普通日期格式

    第一种 function getLocalTime(nS) { return new Date(parseInt(nS) * 1000).toLocaleString().replace(/:\d{1 ...

  4. Cordova(PhoneGap) 环境搭建与基础

    Cordova(PhoneGap) 创建步骤:官方Guide 环境准备 安装 Node.js nodejs.org 安装 git git-scm.com (bin目录添加到path) 安装 cordo ...

  5. 图论基础之Dijkstra算法的初探

         图论,顾名思义就是有图有论.        图:由点"Vertex"和边"Edge "组成,且图分为有向图和无向图(本文讨论有向图),之前做毕业设计的 ...

  6. Tomcat服务器无法启动socket监听端口

    最近生成一个新的web服务器,在启动后无法启动socket监听,检查程序本身无问题, 找原因,只是发布时搞错.处理如下: 1.在Eclipse平台 删除原来的web server; 2.新建serve ...

  7. AngularJS 和 Bootstrap

    AngularJS Bootstrap AngularJS 的首选样式表是 Twitter Bootstrap, Twitter Bootstrap 是目前最受欢迎的前端框架. 查看 Bootstra ...

  8. visual studio问题集合

    1.当前断点不会命中,还没有为该文档加载任何符号 打开visual 2010 工具->选项->调试->符号: 一.手动加载 点击 加载所有符号 即可.二.自动加载 点击"指 ...

  9. [Oracle]高水位标记(HWM)

    (一)高水位标记(High Water Mark,HWM)的概念 所谓高水位标记,是指一个已经分配的段中,已经使用的空间与未使用的空间的分界线.在表的使用过程中,随着数据的不断增多(insert),H ...

  10. es6的新内容

    前端学习总结(十八)ES6--新一代的javascript 发表于2016/6/11 21:44:27  2733人阅读 分类: javascript 简介 ECMAScript 6(以下简称ES6) ...