免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2494 | 回复: 2
打印 上一主题 下一主题

[算法] 地接斯特拉,距离 268435456 是怎么得到的? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-05-30 09:48 |只看该作者 |倒序浏览
#include <stdio.h>
#include <string.h>
#include <math.h>
#define bool int
#define true 1
#define false 0
#define maxedge 20
#define maxn 9  //结点数
#define inf 1<<28
bool vist[maxn];
struct Edge
{
    int s;   //边的起点
    int t;   //边的终点
    int next;//当前下一条边的编号
    int w;  //边的权值
}edge[maxedge];
int headlist[maxedge]; //索引  head[i]存放已i为起点的“第一条”边
int distance[maxn];
int n,m,x;
void dij()
{
    int i,j,k;
   //memset(vist,false,sizeof(vist));
        j=sizeof(vist);
        for(i=0;i<j;i++)
                  vist[i]=0;
    for(i=1;i<=n;++i)
     distance[i]=inf;
     distance[x]=0;
    for(i=1;i<=n;i++)
    {   k=-1;
        for(j=1;j<=n;j++)
          if(!vist[j]&&(k==-1||distance[k]>distance[j]))
            k=j;
        vist[k]=true;
        for(j=headlist[k];j!=-1;j=edge[j].next)
        if(!vist[edge[j].t]&&(distance[k]+edge[j].w<distance[edge[j].t]))
            distance[edge[j].t]=distance[k]+edge[j].w;
    }
        printf("distance are:");

                 for(i=1;i<=n;i++)
  printf("从点%d到点%d的距离是:%d  \n",x,i-1,distance[i]);
   // printf("%d  ",distance[i]);
}
int main()
{
    int i,a,b,c;
        printf("请输入请输入定点数、边数,起始点\n");
    while(~scanf("%d%d%d",&n,&m,&x))
    {       
                printf("顶点数、边数,起始点分别为:%d,%d,%d\n",n,m,x);
        for(i=1;i<=n;++i)
          headlist[i]=-1;
        for(i=1;i<=m;++i)
        {
                        printf("请输入第%d条边的起点、终点、权值\n",i);
            scanf("%d%d%d",&a,&b,&c);
            edge[i].s=a;
            edge[i].t=b;
            edge[i].w=c;
            edge[i].next=headlist[a];//索引:节点i 后一条边编号为headlist[a];
            headlist[a]=i;

        }
        dij();
                printf("\n算的没错吧,再来一次吧。\n\n请输入定点数、边数,起始点:\n");
    }

    return 0;
}


1.
   //memset(vist,false,sizeof(vist));
和j=sizeof(vist);
        for(i=0;i<j;i++)
                  vist[i]=0;
作用是一样的吧?
2.得到的结果没问题,不过,如果无法达到,显示:268435456.268435456为什么是无穷大呢?这个怎么得到的?

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
2 [报告]
发表于 2014-05-30 09:58 |只看该作者

268435456 = 0x10000000,就是你自己初始化的  #define inf 1<<28

论坛徽章:
0
3 [报告]
发表于 2014-05-30 13:45 |只看该作者
回复 2# hellioncu

原来如此啊。。。非常感谢!!
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP