/*
 *题目大意:
 *在一个有向图中,求从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. jquery获取当前选项的属性值a

    <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...

  2. 仿淘宝,京东红包雨(基于Phaser框架)

    本红包雨项目是基于HTML5的游戏框架Phaser写的,最终形成的是一个canvas,所以性能很好,但是必须要说的是这个框架比较大,压缩后也有700K左右,所以请慎用. 代码地址: https://g ...

  3. 【LeetCode】105 & 106. Construct Binary Tree from Inorder and Postorder Traversal

    题目: Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume ...

  4. Redis初体验

    简介        Redis是一个速度非常快的非关系型数据库,它不仅性能强劲,而且还具有复制特性以及为解决问题而生的独一无二的数据模型.作为键值型数据库,Redis支持5中数据类型:字符串,列表,集 ...

  5. Java 面试总结(一) —— 面试常问的关键字总结

    关键字: final finalize finally throws和throw static关键字的作用 abstract 和 interface super 和 this synchronize ...

  6. String详细学习

    学这些东西,就像是扎马步.小说里郭靖学不会招数,就会扎马步.搞JS,内力还是必须要深厚,深厚,深厚. 1,stringObject.slice(start,end) slice() 方法可提取字符串的 ...

  7. window.getSelection和document.selection

    window.getSelection和document.selection   IE9以下支持:document.selection IE9.Firefox.Safari.Chrome和Opera支 ...

  8. fedora下一些问题的解决方案汇总

    解决fedora下一些使用问题 一 解决fedora下无法使用Fn+功能键来调整亮度的问题 在fedora下,背光的配置参数在/sys/class/backlight文件夹下,根据不同的显卡,有不同的 ...

  9. 【Vue】Vue的依赖追踪系统 ——搞懂methods watch和compute

    从作用机制和性质上看待methods,watch和computed的关系 <他三个是啥子关系呢?> 首先要说,methods,watch和computed都是以函数为基础的,但各自却都不同 ...

  10. MongoDB数据库索引

    前面的话 索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录.这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查 ...