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 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿