当前位置: 首页 > news >正文

Acwing.91 最短Hamilton路径(动态规划)

题目

给定一张n个点的带权无向图,点从0~n-1标号,求起点0到终点n-1的最短Hamilton路径。Hamilton路径的定义是从0到n-1不重不漏地经过每个点恰好一次。

输入格式

第—行输入整数n。
接下来n行每行n个整数,其中第i行第j个整数表示点i到j的距离(记为a[i.i])。对于任意的, y,z,数据保证a[x,x]=0,a[x,y]=a[y,x]并且a[x,y]+aly,z]>=a[x,z]。

输出格式

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

数据范围

1 ≤n ≤200≤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

题解

import java.util.Arrays;
import java.util.Scanner;/*** @author akuya* @create 2023-07-28-20:56*/
public class hamiltion {static int N=20;static int M=1<<N;static int n;static int w[][]=new int[N][N];static int f[][]=new int[M][N];public static void main(String[] args) {Scanner scanner=new Scanner(System.in);n=scanner.nextInt();for(int i=0;i<n;i++)for (int j = 0; j < n; j++)w[i][j]=scanner.nextInt();for(int i=0;i<M;i++){Arrays.fill(f[i],0x3f);}f[1][0]=0;for(int i=0;i<1<<n;i++)for(int j=0;j<n;j++)if((i>>j&1)!=0)for(int k=0;k<n;k++)if(((i-(1<<j))>>k&1)!=0)f[i][j]=Math.min(f[i][j],f[i-(1<<j)][k]+w[k][j]);System.out.println(f[(1<<n)-1][n-1]);}
}

思路

本题同样是状态压缩类的动态规划,具体思路如下图
在这里插入图片描述
i代表走过的点,状态转移用到达j点的倒数第二个点,转移方程得出为

f[i][j]=Math.min(f[i][j],f[i-(1<<j)][k]+w[k][j]);

注意边界条件即可

http://www.lryc.cn/news/99454.html

相关文章:

  • [hfut] [important] v4l2 vedio使用总结/opevx/ffpeg/v4l2/opencv/cuda
  • 2023年深圳杯数学建模A题影响城市居民身体健康的因素分析
  • 指令调度(Instruction Scheduling)
  • 【运维】Linux 跨服务器复制文件文件夹
  • k8s apiserver如何支持http访问?
  • Safetensors,高效安全易用的深度学习新工具
  • Unity 工具之 NuGetForUnity 包管理器,方便在 Unity 中的进行包管理的简单使用
  • 运算放大器(二):恒流源
  • 企业选择租用CRM还是一次性买断CRM?分别有哪些优势?
  • VBA_MF系列技术资料1-133
  • Android 项目架构
  • 【Linux】进程通信 — 管道
  • ROS 2 — 托管(生命周期)节点简介
  • vue2企业级项目(六)
  • OSPF的选路原则
  • 4.操作元素属性
  • uniapp 微信小程序:v-model双向绑定问题(自定义 props 名无效)
  • 【Lua学习笔记】Lua进阶——Table(3) 元表
  • AI编程常用工具 Jupyter Notebook
  • RocketMQ重复消费的解决方案::分布式锁直击面试!
  • 如何降低TCP在局域网环境下的数据传输延迟
  • 【LeetCode】78.子集
  • 认可功能介绍 - 技术声誉靠认可
  • EtherNet/IP转CAN网关can协议标准
  • 解决代理IP负载均衡与性能优化的双重挑战
  • 深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析
  • 测牛学堂:软件测试之andorid app性能测试面试知识点总结(二)
  • 尚医通06:数据字典+EasyExcel+mongodb
  • 【前端知识】React 基础巩固(三十二)——Redux的三大原则、使用流程及实践
  • [NLP]使用Alpaca-Lora基于llama模型进行微调教程