zoukankan      html  css  js  c++  java
  • 图论——Dijkstra算法

    本文作者frankchenfu,blogs网址http://www.cnblogs.com/frankchenfu/,转载请保留此文字。

    图论其实是比较难的一种题型,但是一些模板题,是没有什么太大难度的!

    这里给大家带来的是迪杰斯特拉(Dijkstra)算法。

    迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法。

    是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题。

    迪杰斯特拉算法主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。

    #include<cstdio>
    #include<cstring>
    #include<queue>
    #define reg register
    using namespace std;
    const int N=100001;
    const int M=100001;
    int n,m,s,t,d[N];
    int edge,e[M],b[M],w[M],fir[N];
    void add(reg int x,reg int y,reg int z)
    {
        e[++edge]=y;
        w[edge]=z;
        b[edge]=fir[x];
        fir[x]=edge;
    }
    struct node
    {
        int i,di;
    };
    bool operator<(node a,node b)
    {
        return a.di>b.di;
    }
    priority_queue<node>que;
    void input()
    {
        scanf("%d%d%d%d",&n,&m,&s,&t);
        for(reg int i=1;i<=m;i++)
        {
            reg int x,y,z;
            scanf("%d%d%d",&x,&y,&z);
            add(x,y,z);
            add(y,x,z);
        }
        memset(d,0x7f,sizeof(d));
        que.push((node){s,0});
        d[s]=0;
    }
    void work()
    {
        for(;!que.empty();)
        {
            node t=que.top();
            que.pop();
            if(d[t.i]!=t.di)
                continue;
            for(reg int k=fir[t.i];k;k=b[k])
                if(t.di+w[k]<d[e[k]])
                {
                    d[e[k]]=t.di+w[k];
                    que.push((node){e[k],d[e[k]]});
                }
        }
    }
    void output()
    {
        printf("%d
    ",d[t]);
    }
    int main()
    {
        input();
        work();
        output();
        return 0;
    }

    我们看到,一般的Dijkstra算法好像不需要STL,可是这个优先队列呢?它是进行堆优化的。

    理论上,堆优化可以是Dijkstra算法时间复杂度降到O(n log n),这样不是很好吗?多写几行,时间快不少,何乐而不为?

    需要注意的大概就这些,希望大家继续努力,天天AC!

    备注:

    标准模板题是 [USACO09OCT] Heat Wave 热浪。

    链接参考(来自“洛谷”):http://www.luogu.org/problem/show?pid=1339

  • 相关阅读:
    poj 3461 (模式串T在主串S中出现的次数)
    hdu 1711( 模式串T在主串S中首次出现的位置)
    HDU 3980 (SG 环变成链 之前的先手变成后手)
    数据结构 Redo or Undo (模拟)
    数据结构 DNA序列 (KMP+暴力,或者STL+暴力)
    数据结构 英语词典 (STL+ set)
    数据结构 领取礼品的顺序 (STL+模拟)
    数据结构 求表达式串的后缀表达式和值 (栈+模拟)
    数据结构 下车的顺序 (STL+stack)
    数据结构 击鼓传花 (STL+模拟)
  • 原文地址:https://www.cnblogs.com/frankchenfu/p/6368526.html
Copyright © 2011-2022 走看看