| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1094 人关注过本帖
标题:地接斯特拉,距离 268435456 是怎么得到的?
只看楼主 加入收藏
慢跑20
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2013-4-23
结帖率:0
收藏
已结贴  问题点数:10 回复次数:4 
地接斯特拉,距离 268435456 是怎么得到的?
#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为什么是无穷大呢?这个怎么得到的?
搜索更多相关主题的帖子: distance include false 起点 
2014-05-30 09:47
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:4 
问题描述清楚,没懂。


[fly]存在即是合理[/fly]
2014-05-30 13:10
砖家的谎言
Rank: 12Rank: 12Rank: 12
等 级:禁止访问
威 望:30
帖 子:693
专家分:3898
注 册:2013-12-6
收藏
得分:4 
我也不太清楚

我不是砖家,要努力成为砖家。
2014-05-30 18:07
icanbestrong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:100
专家分:138
注 册:2013-3-13
收藏
得分:4 
我知道,楼主想说迪杰斯特拉算法吧,即单源最短路径问题用贪心算法解决的吧,这个说起来还比较麻烦,如果有资料的话,建议看一下《算法设计与分析》,因为这要牵扯到最优子结构性质和贪心选择性质吧,貌似,一句两句说不清楚···
2014-05-31 10:07
trewqyuiop
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2014-8-28
收藏
得分:0 
算法导论这本书不知上面有没有这方面的
2014-09-03 21:32
快速回复:地接斯特拉,距离 268435456 是怎么得到的?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.022248 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved