逐至 2021-04-07 09:35 采纳率: 100%
浏览 113
已采纳

算法题,进链接看文本,不限语言c/c++/python都可以,伪代码也行,请会的留下代码最好带下注释


链接: https://pan.baidu.com/s/1vEu6L27XAzdgkUOuOE-38g

提取码: 1ksf

  • 写回答

3条回答 默认 最新

  • 一切因为有你 2021-04-07 20:11
    关注
        #include <stdio.h>
        int main()
        {
            int e[10][10],dis[10],book[10],i,j,n,m,t1,t2,t3,u,v,min;
            int inf=-99999999; //用inf(infinity的缩写)存储一个我们认为的负无穷值
            //读入n和m,n表示顶点个数,m表示边的条数
            scanf("%d %d",&n,&m);
    
            //初始化
            for(i=1;i<=n;i++)
                for(j=1;j<=n;j++)
                    if(i==j) e[i][j]=0;
                      else e[i][j]=inf;
    
            //读入边
            for(i=1;i<=m;i++)
            {
                scanf("%d %d %d",&t1,&t2,&t3);
                e[t1][t2]=t3;
            }
            //初始化dis数组,这里是1号顶点到其余各个顶点的初始路程
            for(i=1;i<=n;i++)
                dis[i]=e[1][i];
            //book数组初始化
            for(i=1;i<=n;i++)
                book[i]=0;
            book[1]=1;
    
            //Dijkstra算法核心语句
            for(i=1;i<=n-1;i++)
            {
                //找到离1号顶点最近的顶点
                min=inf;
                for(j=1;j<=n;j++)
                {
                    if(book[j]==0 && dis[j]>min)
                    {
                        min=dis[j];
                        u=j;
                    }
                }
                book[u]=1;
                for(v=1;v<=n;v++)
                {
                    if(e[u][v]>inf)
                    {
                        if(dis[v]<dis[u]*e[u][v])
                            dis[v]=dis[u]*e[u][v];
                    }
                }
            }
    
            //输出最终的结果
            for(i=1;i<=n;i++)
                printf("%d ",dis[i]);
    
            getchar();
            getchar();
            return 0;
        }
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。