/*
 *题目大意:
 *在一个有向图中,求从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. a链接返回上一页

    <a href="javascript:void(0);" onclick="javascript:history.go(-1);" style='mar ...

  2. hive集成sentry的sql使用语法

    Sentry权限控制通过Beeline(Hiveserver2 SQL 命令行接口)输入Grant 和 Revoke语句来配置.语法跟现在的一些主流的关系数据库很相似.需要注意的是:当sentry服务 ...

  3. 读书共享 Primer Plus C-part 7

    第十章  数组和指针 1.关于二维数组跟指针 #include<stdio.h> int main() { ][]={{,,,},{,,,},{,,,}}; ; ;i< ;i++) ...

  4. XML 新手入门基础知识(复制,留着自己看)

    如果您是 XML 新手,本文将为您介绍 XML 文档的基础结构,以及创建构造良好的 XML 需要遵循的规则,包括命名约定.正确的标记嵌套.属性规则.声明和实体.您还可以从本文了解到 DTD 和 sch ...

  5. App Extensions篇之Sticker Pack Extension

    转载请标明原文链接:http://www.cnblogs.com/zhanggui/p/7151795.html 前言 上一篇文章对App Extension做了简单介绍以及对Share Extens ...

  6. SSH中的Invalid action class configuration that references an unknown class named.......

    最近用SSH框架做项目的时候页面提交数据到后台,遇到了这个问题,百度了一下,网上的解决办法无非两种: 1.检查struts.xml  ,applicationContext.xml的配置是否正确 2. ...

  7. mysql主从数据库设置备忘

    [mysqld] binlog-do-db = databasename1 binlog-do-db = databasename2 binlog-do-db = databasename3 -- 且 ...

  8. 关于shell脚本函数、数组、字符串截取、svn更新发布实例

    #/bin/bash #功能:QA服根据模板创建区配置文件并提交到svn上. SOURCE_PATH=/data/source_code SVN_PATH=/code/psm   #svn发布目录,要 ...

  9. 【转载】CANoe 入门 Step by step系列(一)基础应用

    来源:http://www.cnblogs.com/dongdonghuihui/archive/2012/09/26/2704611.html CANoe是Vector公司的针对汽车电子行业的总线分 ...

  10. Spring定时器实现(一)

    Spring定时器简单应用实现,如下: 首先.Spring配置文件: <?xml version="1.0" encoding="UTF-8"?> ...