pengtianshi999 2019-03-21 23:13 采纳率: 50%
浏览 322

dijkstra算法过程中的问题

int dejie(ALGraph G,int i,int j)
{
ArcNode *p;
int v,x,m,start,k,w,y,o;
int D[8],M[8];

p=(ArcNode*)malloc(sizeof(ArcNode));
for(v=0;v<8;v++)
D[v]=10000;
for(x=0;x<8;x++)
M[x]=0;

start=i;
M[0]=1; 
k=G.vertices[i].firstarc->lang;
D[G.vertices[i].firstarc->adjvex]=k;
p=G.vertices[i].firstarc;
M[G.vertices[i].firstarc->adjvex]=1;

for(o=NextAdjVex(G,aaa(i),aaa(G.vertices[i].firstarc->adjvex));o;o=NextAdjVex(G,aaa(i),aaa(o)))
{
    p=p->nextarc;
  D[o]=p->lang;
  M[o]=1;
}
//for(m=1;m<7;m++)
for(w=0;w<7;w++)//===================
{
  if(D[w]<10000&&M[w]==0)
  {

    start=w;
    k=G.vertices[start].firstarc->lang;
    D[G.vertices[start].firstarc->adjvex]=D[start]+k;
    p=G.vertices[start].firstarc;
    M[G.vertices[start].firstarc->adjvex]=1;
  for(y=NextAdjVex(G,aaa(start),aaa(G.vertices[start].firstarc->adjvex));y;y=NextAdjVex(G,aaa(start),aaa(y)))
  {
    p=p->nextarc;
    D[y]=p->lang;
    M[y]=1;
  } 
  }
}

return 1;

}
在for(w=0;w 调试时w显示的是4199049地址,而不是0这是为什么,而且return 1失效;但把
for(o=NextAdjVex(G,aaa(i),aaa(G.vertices[i].firstarc->adjvex));o;o=NextAdjVex(G,aaa(i),aaa(o)))
{
p=p->nextarc;
D[o]=p->lang;
M[o]=1;
}
这行代码去掉ruturn 1就有显示了

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-09-09 16:18
    关注
    不知道你这个问题是否已经解决, 如果还没有解决的话:

    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 以帮助更多的人 ^-^
    评论

报告相同问题?

悬赏问题

  • ¥15 thinkphp6配合social login单点登录问题
  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch