P3052 奶牛坐电梯
又是传送门
思路
是二元组,第一个表示多少趟,第二个表示目前奶牛总载重。
显然,按多少趟来排,相等按载重来排。
那状态转移方程就好推了。
话说博主真水(
代码
#include <bits/stdc++.h>
using namespace std;
int w[20];
pair<int, int> f[1 << 20];
int main() {
int n, W;
scanf("%d %d", &n, &W);
for (int i = 0; i < n; i++) {
scanf("%d", &w[i]);
}
for (int i = 0; i < (1 << n); i++) {
f[i].first = 0x3f3f3f3f;
}
f[0].first = 0, f[0].second = 0;
for (int i = 0; i < (1 << n); i++) {
for (int j = 0; j < n; j++) {
if ((i >> j) & 1) {
continue;
}
int a, b;
if (f[i].second + w[j] > W) { // 那么这儿就是状态转移方程!
a = f[i].first + 1;
b = w[j];
} else {
a = f[i].first;
b = f[i].second + w[j];
}
f[i | (1 << j)] = min(f[i | (1 << j)], make_pair(a, b));
}
}
if (f[(1 << n) - 1].second) {
printf("%d", f[(1 << n) - 1].first + 1);
} else {
printf("%d", f[(1 << n) - 1].first);
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!