m0_57117352 2022-04-15 15:10 采纳率: 81.3%
浏览 55
已结题

迪杰斯特拉求任意一点的最短路径问题遇到错误情况无法实现

代码运行结果不对怎么直接就输出结果了,还有通过visit数组来判断是否经过那个点不知道正不正确

#include<stdio.h>
#define SIZE 110
#define INF 1000000;
int map[SIZE][SIZE]; //邻接矩阵存储
int len[SIZE]; //d[i]表示源点到i这个点的距离
int visit[SIZE]; //节点是否被访问
int n,m,j,pos,ans,temp;
int temp = INF;

int dijkstra(int from, int to){ //从源点到目标点
int i;
for(i = 1 ; i <= n ; i ++){ //初始化
visit[i] = 0; //一开始每个点都没被访问
len[i] = map[from][i]; //先假设源点到其他点的距离
}

for(i = 1 ; i < n ; ++i){    //对除源点的每一个点进行最短计算 
    int min = INF;  //记录最小len[i] 
      //记录小len[i] 的点 
    for(j = 1 ; j <= n ; ++j){    
        if(!visit[j] && min > len[j]){  
            pos = j;  
            min = len[j];  
        }  
    }  
    visit[pos] = 1;  
    for(j = 1 ; j <= n ; ++j){
        if(!visit[j] && (len[j] > (len[pos] +map[pos][j]))){ //如果j节点没有被访问过&&j节点到源节点的最短路径>pos节点到源节点的最短路径+pos节点到j节点的路径  
            len[j] = len[pos] + map[pos][j];    //更新j节点到源节点的最短路径    
        }  
    }  
}  
return len[to];

}

int main ()
{

int i,j;  

int ans,u,v;

printf("输入顶点和边数");
scanf("%d%d",&n,&m);    //输入数据


for(i = 1 ; i <= n ; ++i){    //设一开始每个点都不可达 
    for(j = 1 ; j <= n ; ++j){  
        map[i][j] = INF;  
    }  
}  

int a,b,c;    //输入数据 
for(i = 1 ; i <= m ; ++i){  
    scanf("%d%d%d",&a,&b,&c);  
    map[a][b] = map[b][a] = c;  
}  

printf("输入起点和终点:");
scanf("%d,%d",&u,&v);

ans=dijkstra(u,v);
for(i=0;i<=n;i++)//输出途径点 
{
    if(visit[i]==1)
    {
        printf("%d",i);
    }
}
printf("%d",ans);  

return 0;  

}

img

  • 写回答

3条回答 默认 最新

  • CSDN专家-link 2022-04-15 15:33
    关注

    #define INF 1000000; 这里的分号去掉
    输入3 2,中间不能带逗号, 因为你是scanf("%d%d",&n,&m);,两个%d之间没有逗号

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月28日
  • 已采纳回答 4月20日
  • 创建了问题 4月15日

悬赏问题

  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码