dij 邻接表
来源:互联网 发布:编程语言的都有啥 编辑:程序博客网 时间:2024/06/06 00:21
#include<stdio.h>
#include<string.h>
struct Ele
{
int to;
int w;
int next;
} p[100000];
int head[100000];
int lowcost[100000];
bool Mark[100000];
int e;
void Dij(int x,int n)
{
int i,j,k;
for(i=1;i<=n;i++)
lowcost[i]=99999999;
for(i=head[x];i!=-1;i=p[i].next)
lowcost[p[i].to]=p[i].w;
lowcost[x]=0;
Mark[x]=true;
for(i=1;i<=n-1;i++)
{
int Min=99999999;
for(j=1;j<=n;j++)
if(!Mark[j]&&lowcost[j]<Min)
{
k=j;
Min=lowcost[j];
}
Mark[k]=true;
for(j=head[k];j!=-1;j=p[j].next)
{
if(!Mark[p[j].to]&&lowcost[p[j].to]>lowcost[k]+p[j].w)//mark[p[j].to]
lowcost[p[j].to]=lowcost[k]+p[j].w;
}
}
}
void Add(int x,int y,int z)
{
p[e].to=y;
p[e].w=z;
p[e].next=head[x];
head[x]=e++;
}
int main()
{
int n,m;
int x,y,z;
while(scanf("%d%d",&n,&m),n&&m)
{
e=0;
memset(head,-1,sizeof(head));
while(m--)
{
scanf("%d%d%d",&x,&y,&z);
Add(x,y,z);
Add(y,x,z);
}
memset(Mark,false,sizeof(Mark));
Dij(1,n);
printf("%d\n",lowcost[n]);
}
return 0;
}
#include<string.h>
struct Ele
{
int to;
int w;
int next;
} p[100000];
int head[100000];
int lowcost[100000];
bool Mark[100000];
int e;
void Dij(int x,int n)
{
int i,j,k;
for(i=1;i<=n;i++)
lowcost[i]=99999999;
for(i=head[x];i!=-1;i=p[i].next)
lowcost[p[i].to]=p[i].w;
lowcost[x]=0;
Mark[x]=true;
for(i=1;i<=n-1;i++)
{
int Min=99999999;
for(j=1;j<=n;j++)
if(!Mark[j]&&lowcost[j]<Min)
{
k=j;
Min=lowcost[j];
}
Mark[k]=true;
for(j=head[k];j!=-1;j=p[j].next)
{
if(!Mark[p[j].to]&&lowcost[p[j].to]>lowcost[k]+p[j].w)//mark[p[j].to]
lowcost[p[j].to]=lowcost[k]+p[j].w;
}
}
}
void Add(int x,int y,int z)
{
p[e].to=y;
p[e].w=z;
p[e].next=head[x];
head[x]=e++;
}
int main()
{
int n,m;
int x,y,z;
while(scanf("%d%d",&n,&m),n&&m)
{
e=0;
memset(head,-1,sizeof(head));
while(m--)
{
scanf("%d%d%d",&x,&y,&z);
Add(x,y,z);
Add(y,x,z);
}
memset(Mark,false,sizeof(Mark));
Dij(1,n);
printf("%d\n",lowcost[n]);
}
return 0;
}
0 0
- dij 邻接表
- hdu2680(邻接表+dij)
- POJ1724 Dij队列优化邻接表
- hdu 1874 畅通工程续(最短路Dij邻接表)
- 邻接表用数组模拟+dij+优先队列,dfs剪枝+邻接表用数组模拟,链表+dij+优先队列
- 哈理工oj Touring (最短路 dij算法 邻接表 + 队列 )
- 哈理工oj/hrbust 2122 旅行【dij+优先队列优化+邻接表+map】
- 图论: 邻接表 + STL优先队列 + dij…
- Dij
- 邻接表
- 邻接表
- 邻接表
- 邻接表
- 邻接表
- 邻接表
- 邻接表
- 邻接表
- 邻接表
- 获得本机的用户名及IP地址函数
- 改变UITextField placeHolder颜色、字体
- git冲突时的处理
- 指针
- Pelican 的Windows 入门教程
- dij 邻接表
- “华夏”从何而来
- 谈谈开源技术选型
- 用C#去除字符串中HTML的格式(清除数据库中html标签)
- 杭电ACM 2024C语言合法标识符-----20140726
- 非常容易用错的 ss
- android基础笔记:ContentValues应用(查询、添加手机联系人)
- 动态链接库(DLL)重定址
- eclipse Hadoop开发环境配置