题目传送门

https://lydsy.com/JudgeOnline/problem.php?id=4145

题解

好像这道题有不少方法呢。

...谁叫这道题有点简单,所以方法多呗。

我的方法:

求出 \(f[S]\) 表示要在同一家商店购买 \(S\) 中的物品的最小代价。

然后 \(dp[S]\) 表示购买 \(S\) 中的商品的最小代价。枚举子集转移即可。

时间复杂度 \(O(m2^n+3^n)\)。


还有一个不错的做法:

\(dp[i][S]\) 表示在前 \(i\) 个商店买 \(S\) 中的物品的最小代价。

于是转移的时候,如果决定要在 \(i\) 中买——那么先对所有状态加上路费,然后枚举每一个商品背包转移就可以了。


只写了我的做法。

#include<bits/stdc++.h>

#define fec(i, x, y) (int i = head[x], y = g[i].to; i; i = g[i].ne, y = g[i].to)
#define dbg(...) fprintf(stderr, __VA_ARGS__)
#define File(x) freopen(#x".in", "r", stdin), freopen(#x".out", "w", stdout)
#define fi first
#define se second
#define pb push_back template<typename A, typename B> inline char smax(A &a, const B &b) {return a < b ? a = b, 1 : 0;}
template<typename A, typename B> inline char smin(A &a, const B &b) {return b < a ? a = b, 1 : 0;} typedef long long ll; typedef unsigned long long ull; typedef std::pair<int, int> pii; template<typename I> inline void read(I &x) {
int f = 0, c;
while (!isdigit(c = getchar())) c == '-' ? f = 1 : 0;
x = c & 15;
while (isdigit(c = getchar())) x = (x << 1) + (x << 3) + (c & 15);
f ? x = -x : 0;
} #define lowbit(x) ((x) & -(x)) const int N = 16 + 7;
const int M = 100 + 7;
const int NP = (1 << 16) + 7; int m, n, S;
int a[M][N];
int f[NP], t[NP], dp[NP]; inline void ycl() {
S = (1 << n) - 1;
memset(f, 0x3f, sizeof(f));
for (int i = 1; i <= m; ++i) {
t[0] = a[i][0];
for (int s = 1; s <= S; ++s) t[s] = t[s ^ lowbit(s)] + a[i][std::__lg(lowbit(s)) + 1];
for (int s = 0; s <= S; ++s) smin(f[s], t[s]);
}
} inline void work() {
ycl();
memset(dp, 0x3f, sizeof(dp));
dp[0] = 0;
for (int s = 1; s <= S; ++s)
for (int sta = s; sta; sta = (sta - 1) & s)
smin(dp[s], f[sta] + dp[s ^ sta]);
printf("%d\n", dp[S]);
} inline void init() {
read(m), read(n);
for (int i = 1; i <= m; ++i)
for (int j = 0; j <= n; ++j) read(a[i][j]);
} int main() {
#ifdef hzhkk
freopen("hkk.in", "r", stdin);
#endif
init();
work();
fclose(stdin), fclose(stdout);
return 0;
}

最新文章

  1. HQL查询——关联和连接
  2. 屠龙之路_向恶龙Alpha进发_FirstDay
  3. Npoi实现Excel绘制功能
  4. 20145212 《Java程序设计》第2周学习总结
  5. 命令行启动tomcat,怎么配置
  6. 第二周02:Fusion ICP逐帧融合
  7. IT痴汉的工作现状18-思维定式
  8. POJ1200(hash)
  9. NetCore1.1+Linux部署初体验
  10. 一些常用的集合工具的代码块(缓慢更新XD)
  11. jQuery中使用$.each()遍历后台响应的json字符串问题
  12. 喝汤 beautifulsoup 批量爬取图片
  13. python学习心得--编码格式篇
  14. Servlet 使用ServletConfig对象来配置Servlet
  15. shell中数组及其相关操作
  16. 2)django-请求生命周期
  17. [No0000136]6个重要的.NET概念:栈,堆,值类型,引用类型,装箱,拆箱
  18. C#操作Sqlite快速入门及相关工具收集
  19. django model 插入数据方法
  20. JVM笔记6-垃圾回收器

热门文章

  1. php中魔术方法有什么用
  2. mysql 1067 - Invalid default value for &#39;addtime&#39;错误处理
  3. [CSP-S模拟测试]:凤凰院凶真(LCIS)
  4. python中的方法使用
  5. 我的Podfile如下
  6. 131、TensorFlow保存模型
  7. phpcms php格式化 时间戳
  8. EasyUI的时间控件禁止输入
  9. 转 Python selenium 强制等待显示等待隐式等待
  10. Maven安装、配置环境变量