最佳挑水 题解

这篇博客介绍了一个关于挑水的问题,小Y需要在家中n个不同容量的桶中挑水,每对桶挑水所需时间不同。任务是找到最小时间填满所有桶。博主提出了使用动态规划的方法,通过状态转移方程f[s]表示当前桶装满状态s的最少时间,最终给出最佳挑水方案的最少时间。
摘要由CSDN通过智能技术生成

最佳挑水

Description

小Y住在农村,离他的家不远有一口井,传说是小Y的祖先开掘的。虽然小Y的村子里通了自来水,但由于这口井的井水质量非常好,因此小Y家仍然喝这口井里的水。小Y非常喜欢这口井,所以他经常去挑水。
  小Y的家里有n(n是偶数)只桶,这些桶虽然大小相等,但是由于很多都有些破损,所以认为它们是不同的。小Y经常挑一根扁担(当然一定是带两只空桶)去井边挑水。小Y每次去井旁都会把桶中的水装到极限(假设水量无穷,且小Y都能够挑得动)。设小Y挑得是i,j两只桶,则挑水一趟需要走time[i,j]分钟。小Y想要在最少的时间内用自己的力量把家里所有的空桶装满。
  小Y觉得这是个难题,于是来找你帮忙编写一个程序来找出一种最佳挑水方案。

Input

输入文件中的的第一行为一个整数n(4<=n<=18)。
接下来的n行,每行有n个数,表示了time矩阵。其中:time矩阵中每一个数都是小于等于32768正整数,且time[i,i]是没有用的。
注意:time[i,j]=time[j,i]。

Output

输出文件中仅一行为一个数,即最佳挑水方案的最少时间。

Sample Input

4
0 100 5 100
100 0 100 11
5 100 0 100
100 11 100 0

Sample Output

16

题解

看到数据范围 n ≤ 18 n≤18 n18这么小,我们就可以愉快地考虑状压了
f [ s ] f[s] f[s]表示当前桶装满的状态为 s s s所需要的最少时间(1表示装满,0表示没装),之后直接枚举两个点暴力转移DP就行了

CODE

#include<cstdio>
#include<string>
#include
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>