acwing-91. 最短Hamilton路径(状态压缩dp)

acwing-91. 最短Hamilton路径(状态压缩dp)给定一张 n 个点的带权无向图,点从 0∼n−1 标号,求起点 0 到终点 n−1 的最短 Hamilton 路径。Hamilton 路径的定义是从 0 到 n−1 不重不漏地经过每个点恰好一次。输入格式第一行输入整数 n。接下来 n 行每行 n 个整数,其中第 i 行第 j 个整数表示点 i 到 j 的距离(记为 a[i,j])。对于任意的 x,y,z,数据保证 a[x,x]=0,a[x,y]=a[y,x] 并且 a[x,y]+a[y,z]≥a[x,z]。输出格式输出一个整数,表示最短 Ha

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一张 n 个点的带权无向图,点从 0∼n−1 标号,求起点 0 到终点 n−1 的最短 Hamilton 路径。

Hamilton 路径的定义是从 0 到 n−1 不重不漏地经过每个点恰好一次。

输入格式
第一行输入整数 n。

接下来 n 行每行 n 个整数,其中第 i 行第 j 个整数表示点 i 到 j 的距离(记为 a[i,j])。

对于任意的 x,y,z,数据保证 a[x,x]=0,a[x,y]=a[y,x] 并且 a[x,y]+a[y,z]≥a[x,z]。

输出格式
输出一个整数,表示最短 Hamilton 路径的长度。

数据范围
1≤n≤20
0≤a[i,j]≤107

输入样例:
5
0 2 4 5 1
2 0 6 5 3
4 6 0 8 3
5 5 8 0 5
1 3 3 5 0
输出样例:
18
#include<bits/stdc++.h>
using namespace std;
const int N = 21;
const int INF = 0x3f3f3f3f;
int f[1 << N][N];
int gg[N][N];
int main(){ 
   
    int n;
    scanf("%d",&n);
    memset(gg,INF,sizeof gg);
    for(int i = 0;i < n;i ++){ 
   
        for(int j = 0;j < n;j ++){ 
   
            scanf("%d",&gg[i][j]);
        }
    }
    memset(f,0x3f,sizeof f);
    f[1][0] = 0;
    for(int s = 0;s < 1 << n;s ++){ 
   
        for(int u = 0;u < n;u ++){ 
   
            if(!(s >> u & 1))continue;
            int pre = s - (1 << u);
            for(int k = 0;k < n;k ++){ 
   
                if((pre >> k & 1) && gg[k][u] > 0){ 
   
                    f[s][u] = min(f[s][u],f[pre][k] + gg[k][u]);
                }
            }
        }
    }
    cout<<f[(1 << n) - 1][n - 1]<<endl;
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168537.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月9日 下午5:00
下一篇 2022年8月9日 下午5:00


相关推荐

  • 手把手教你Tomcat配置环境变量以及验证方法

    手把手教你Tomcat配置环境变量以及验证方法场景现在要将Tomcat配置进环境变量。实现以win7为例,找到桌面计算机图表,右键属性。或者打开计算机,找到系统属性。然后找到高级系统设置找到环境变量点击系统变量下的新建找到Tomcat所在目录变量名为:CATALINA_BASE内容为Tomcat所在路径,这里是上面的路径如图:点击确定同理再新建系统变量,变量名…

    2022年6月4日
    34
  • 闫学灿acwing_算法基础课acwing下载

    闫学灿acwing_算法基础课acwing下载给定一个长度为 N 的数列 A,以及 M 条指令,每条指令可能是以下两种之一:C l r d,表示把 A[l],A[l+1],…,A[r] 都加上 d。Q l r,表示询问数列中第 l∼r 个数的和。对于每个询问,输出一个整数表示答案。输入格式第一行两个整数 N,M。第二行 N 个整数 A[i]。接下来 M 行表示 M 条指令,每条指令的格式如题目描述所示。输出格式对于每个询问,输出一个整数表示答案。每个答案占一行。数据范围1≤N,M≤105,|d|≤10000,|A[i]|≤1

    2022年8月9日
    24
  • 拉姆达表达式/Lambda表达式/lambda expression 使用整理

    拉姆达表达式/Lambda表达式/lambda expression 使用整理一、Lamabda表达式定义二、Lamabda表达式语法三、C#中Lamabda使用场景四、J

    2025年7月13日
    5
  • Sublime Text3使用Package Control 报错There Are No Packages Available For Installation

    Sublime Text3使用Package Control 报错There Are No Packages Available For Installation在使用sublime时,有时候我们希望将代码复制出来后仍然是高亮显示,这样我们便需要安装SublimeHighLight插件,在安装SublimeHighLight插件之前,我们应该先安装PackageControl插件!1、PackageControl插件作用:能够利用这个插件安装很多Sublime的插件!2、SublimeHighLight插件作用:能让代码更好地展示其高亮性!我先从网上

    2022年7月11日
    24
  • xcode编辑xib文件无限卡与编译错误解决

    xcode编辑xib文件无限卡与编译错误解决

    2021年9月8日
    75
  • mysql 10055 解决_mysql 10055 错误解决方案

    mysql 10055 解决_mysql 10055 错误解决方案Description 环境 Windows2003 IIS PHP MYSQL 服务器运行一段时间后 提示 Can tconnecttoMy localhost 10055 错误 无法重启 mysql 服务 提示端口被占 检查发现端口并没被占 重起服务器后恢复正常 但过一段时间以后 又出现此错误 查看 MYSQL 日志 并无不正常记录 Solution 此

    2026年3月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号