dij算法堆优化_Dijkstra算法+堆优化(模板)

/*

使用优先队列Dijkstra算法

复杂度O(ElogE)

注意对vector E[MAXN]进行初始化后加边

*/

#include

#include

#include

#include

#include

#include

using namespace std;

const int INF=0x3f3f3f3f;

const int MAXN=1000010;

struct qnode

{

int v;

int c;

qnode(int _v=0,int _c=0):v(_v),c(_c){}

bool operator

{

return c>r.c;

}

};

struct Edge

{

int v,cost;

Edge(int _v=0,int _cost=0):v(_v),cost(_cost){}

};

vector E[MAXN];

bool vis[MAXN];

int dist[MAXN];

void Dijkstra(int n,int start)//点的编号从1开始

{

memset(vis,false,sizeof(vis));

for(int i=1;i<=n;i++) dist[i]=INF;

priority_queue que;

while(!que.empty()) que.pop();

dist[start]=0;

que.push(qnode(start,0));

qnode tmp;

while(!que.empty())

{

tmp=que.top();

que.pop();

int u=tmp.v;

if(vis[u]) continue;

vis[u]=true;

for(int i=0;i

{

int v=E[tmp.v][i].v;

int cost=E[u][i].cost;

if(!vis[v]&&dist[v]>dist[u]+cost)

{

dist[v]=dist[u]+cost;

que.push(qnode(v,dist[v]));

}

}

}

}

void addedge(int u,int v,int w)

{

E[u].push_back(Edge(v,w));

}

int main()

{

for(int i=0;i<=MAXN;i++)

if(!E[i].empty())

E[i].clear();

freopen("in.txt","r",stdin);

int n;

cin>>n;

int e;

cin>>e;

int u,v,w;

for(int i=1;i<=e;i++)

{

cin>>u>>v>>w;

addedge(u,v,w);

}

Dijkstra(n,1);

for(int i=1;i<=n;i++)

cout<

cout<

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值