lyh不会打代码 2023-04-15 18:58 采纳率: 70%
浏览 18
已结题

关于#全源最短路#的问题,如何解决?

今天做多源最短路,遇到下面问题:

传送门

图片:

img

只拿了90分(满分100)
我的代码如下:

#include<bits/stdc++.h>
using namespace std;
int n,m,d[105][105],p;
long long anss=0x7fffffff; 
bool bo[105],vis[105];
void dfs(int x,int m,long long ss)
{
    if(m>=p)
    {
        anss=min(anss,ss+d[x][n]);
        return;
    }
    else
    {
        for(int i=1;i<=n;i++)
        {
            if(!vis[i]&&bo[i])
            {
                vis[i]=true;
                dfs(i,m+1,ss+d[x][i]);
                vis[i]=false;
            }
        }
    }
}
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
         for(int j=1;j<=n;j++)
         {
             scanf("%d",&d[i][j]);
        }
    }
    for(int k=1;k<=n;k++)
    {
        for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=n;j++)
            {
                if(d[i][k]!=0&&d[k][j]!=0)
                d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
            }
        }
    }
    scanf("%d",&p);
    for(int i=1;i<=p;i++)
    {
        int x;
        scanf("%d",&x);
        bo[x]=true; 
    }
    vis[1]=true;
    dfs(1,1,0);
    printf("%lld",anss);
} 

  • 写回答

1条回答 默认 最新

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 8月16日
  • 创建了问题 4月15日

悬赏问题

  • ¥200 csgo2的viewmatrix值是否还有别的获取方式
  • ¥15 Stable Diffusion,用Ebsynth utility在视频选帧图重绘,第一步报错,蒙版和帧图没法生成,怎么处理啊
  • ¥15 请把下列每一行代码完整地读懂并注释出来
  • ¥15 pycharm运行main文件,显示没有conda环境
  • ¥15 寻找公式识别开发,自动识别整页文档、图像公式的软件
  • ¥15 为什么eclipse不能再下载了?
  • ¥15 编辑cmake lists 明明写了project项目名,但是还是报错怎么回事
  • ¥15 关于#计算机视觉#的问题:求一份高质量桥梁多病害数据集
  • ¥15 特定网页无法访问,已排除网页问题
  • ¥50 如何将脑的图像投影到颅骨上