zoukankan      html  css  js  c++  java
  • Dijkstra堆优化与SPFA模板

    Dijkstra+优先队列

    #include<cstdio>
    #include<cctype>
    #include<queue>
    #include<cstring>
    #include<algorithm>
    #include<queue>
    using namespace std;
    inline int read() {
        int x=0,f=1;char c=getchar();
        for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
        for(;isdigit(c);c=getchar()) x=x*10+c-'0';
        return x*f;
    }
    const int maxn=100010;
    const int maxm=1000010;
    struct Dijkstra {
        int n,m,first[maxn],next[maxm],done[maxn],d[maxn];
        struct Edge {int from,to,dist;}edges[maxm];
        struct HeapNode {
            int d,u;
            bool operator < (const HeapNode& ths) const {return d>ths.d;}
        };
        void init(int n) {
            this->n=n;m=0;
            memset(first,0,sizeof(first));
        }
        void AddEdge(int u,int v,int w) {
            edges[++m]=(Edge){u,v,w};next[m]=first[u];first[u]=m;
        }
        void solve(int s) {
            priority_queue<HeapNode> Q;
            memset(done,0,sizeof(done));
            for(int i=1;i<=n;i++) d[i]=1000000000;
            d[s]=0;Q.push((HeapNode){0,s});
            while(!Q.empty()) {
                int x=Q.top().u;Q.pop();
                if(done[x]) continue;done[x]=1;
                for(int i=first[x];i;i=next[i]) {
                    Edge& e=edges[i];
                    if(d[e.to]>d[x]+e.dist) {
                        d[e.to]=d[x]+e.dist;
                        Q.push((HeapNode){d[e.to],e.to});
                    }
                }
            }
        }
    }sol;
    int main() {
        int n=read(),m=read();sol.init(n);
        for(int i=1;i<=m;i++) {
            int u=read(),v=read(),w=read();
            sol.AddEdge(u,v,w);        
        }
        sol.solve(1);
        for(int i=1;i<=n;i++) printf("%d ",sol.d[i]);
        return 0;    
    }
    /*
    7 8
    1 3 5
    1 4 2
    1 5 1
    4 3 2
    3 6 2
    4 6 3
    6 7 3
    5 7 1
    */
    View Code

     SPFA

    #include<cstdio>
    #include<cctype>
    #include<queue>
    #include<cstring>
    #include<algorithm>
    #include<queue>
    using namespace std;
    inline int read() {
        int x=0,f=1;char c=getchar();
        for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
        for(;isdigit(c);c=getchar()) x=x*10+c-'0';
        return x*f;
    }
    const int maxn=100010;
    const int maxm=1000010;
    struct SPFA {
        int n,m,first[maxn],next[maxm],inq[maxn],d[maxn];
        struct Edge {int from,to,dist;}edges[maxm];
        void init(int n) {
            this->n=n;m=0;
            memset(first,0,sizeof(first));
            memset(inq,0,sizeof(inq));
        }
        void AddEdge(int u,int v,int w) {
            edges[++m]=(Edge){u,v,w};next[m]=first[u];first[u]=m;
        }
        void solve(int S) {
            queue<int> Q;Q.push(S);
            for(int i=1;i<=n;i++) d[i]=1000000000;d[S]=0;
            while(!Q.empty()) {
                int u=Q.front();Q.pop();inq[u]=0;
                for(int i=first[u];i;i=next[i]) {
                    Edge& e=edges[i];
                    if(d[e.to]>d[u]+e.dist) {
                        d[e.to]=min(d[e.to],d[u]+e.dist);
                        if(!inq[e.to]) inq[e.to]=1,Q.push(e.to); 
                    } 
                }
            }
        }
    }sol;
    int main() {
        int n=read(),m=read();sol.init(n);
        for(int i=1;i<=m;i++) {
            int u=read(),v=read(),w=read();
            sol.AddEdge(u,v,w);        
        }
        sol.solve(1);
        for(int i=1;i<=n;i++) printf("%d ",sol.d[i]);
        return 0;    
    }
    /*
    7 8
    1 3 5
    1 4 2
    1 5 1
    4 3 2
    3 6 2
    4 6 3
    6 7 3
    5 7 1
    */
    View Code

     SPFA优化(还是有些用的)

    #include<cstdio>
    #include<cctype>
    #include<queue>
    #include<cstring>
    #include<algorithm>
    #include<queue>
    using namespace std;
    inline int read() {
        int x=0,f=1;char c=getchar();
        for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
        for(;isdigit(c);c=getchar()) x=x*10+c-'0';
        return x*f;
    }
    const int maxn=100010;
    const int maxm=1000010;
    struct SPFA {
        int n,m,first[maxn],next[maxm],inq[maxn],d[maxn];
        struct Edge {int from,to,dist;}edges[maxm];
        void init(int n) {
            this->n=n;m=0;
            memset(first,0,sizeof(first));
            memset(inq,0,sizeof(inq));
        }
        void AddEdge(int u,int v,int w) {
            edges[++m]=(Edge){u,v,w};next[m]=first[u];first[u]=m;
        }
        void solve(int S) {
            deque<int> Q;Q.push_back(S);
            for(int i=1;i<=n;i++) d[i]=1000000000;d[S]=0;
            while(!Q.empty()) {
                int u=Q.front();Q.pop_front();inq[u]=0;
                for(int i=first[u];i;i=next[i]) {
                    Edge& e=edges[i];
                    if(d[e.to]>d[u]+e.dist) {
                        d[e.to]=min(d[e.to],d[u]+e.dist);
                        if(!inq[e.to]) {
                            inq[e.to]=1;
                            if(!Q.empty()&&d[e.to]<d[Q.front()]) Q.push_front(e.to);
                            else Q.push_back(e.to); 
                        }
                    } 
                }
            }
        }
    }sol;
    int main() {
        int n=read(),m=read();sol.init(n);
        for(int i=1;i<=m;i++) {
            int u=read(),v=read(),w=read();
            sol.AddEdge(u,v,w);        
        }
        sol.solve(1);
        for(int i=1;i<=n;i++) printf("%d ",sol.d[i]);
        return 0;    
    }
    /*
    7 8
    1 3 5
    1 4 2
    1 5 1
    4 3 2
    3 6 2
    4 6 3
    6 7 3
    5 7 1
    */
    View Code
  • 相关阅读:
    ubuntu16.04服务自启动(弹控制台)
    第十集 爱在天路唐古拉,青藏梦止长江源
    第九集 生死穿越风火山,感受尘世间轮回
    第八集 昆仑初度尘未洗,夜宿禁区五道梁
    第七集 久历风尘凡间路,终见西域玉珠峰
    第六集 飞沙走石共患难,夜扎昆仑饮圣泉
    第五集 插肩而过茶卡湖,朝发夕至格尔木
    辞职之后在家的挣扎与老爸的工作
    2018,怎么这么难,我该怎么办,我的ai和感情
    17年11月兄弟小聚
  • 原文地址:https://www.cnblogs.com/wzj-is-a-juruo/p/4627205.html
Copyright © 2011-2022 走看看