每日一题-动态规划(从不同类型的物品中各挑选一个,使得最后花费总和等于1000)

四种类型的物品,每一种类型物品数量都是n,先要从每种类型的物品中挑选一件,使得最后花费总和等于1000

暴力做法10000^4

看到花费总和是1000,很小且固定的数字,肯定有玄机,从这里想应该是用dp,不难想到用dp[i][j]表示前i种类型的物品花费为j的方案数量,思考转移方程:

dp[i][j] = dp[i-1][j-A] * js[i][A],js[i][A]表示i类型的物件花销为A的方案数量,如此只需要枚举j和A,它们的范围就是1000以内

cpp 复制代码
#include <iostream>
#include <vector>
#define ios ios::sync_with_stdio(0);cin.tie(0);cout.tie(0)
using namespace std;

int dp[5][1100], js[5][11000];
int n;
vector<int> ve[5];
int main() {
    ios;
    cin >> n;
    for(int i = 1; i <= n; i ++) {
    	int a, b , c, d;
    	cin >> a >> b >> c >> d;
    	ve[1].push_back(a);
    	ve[2].push_back(b);
    	ve[3].push_back(c);
    	ve[4].push_back(d);
	}
	for(int i = 1; i <= 4; i++) {
		for(int j = 0; j < ve[i].size(); j++) {
			js[i][ve[i][j]] ++;
		}
	}
	for(auto p : ve[1]) {
		dp[1][p] ++;
	}
	for(int i = 2; i <= 4; i++) {
		for(int j = 1; j <= 1000; j++) {
			if(js[i][j]) {
				for(int k = j; k <= 1000; k++) {
					dp[i][k] += dp[i-1][k-j] * js[i][j];
				}
			}
		}
	}
	cout << dp[4][1000];
    return 0;
}
/*
3
250 250 250 250
156 201 205 400
205 190 100 250
*/
相关推荐
好易学·数据结构1 小时前
可视化图解算法57:字符串的排列
数据结构·算法·leetcode·面试·笔试·回溯算法·牛客
এ᭄画画的北北3 小时前
力扣-283.移动零
算法·leetcode
2501_924879366 小时前
口罩识别场景误报率↓79%:陌讯多模态融合算法实战解析
人工智能·深度学习·算法·目标检测·智慧城市
Christo36 小时前
TFS-2022《A Novel Data-Driven Approach to Autonomous Fuzzy Clustering》
人工智能·算法·机器学习·支持向量机·tfs
木木子99996 小时前
超平面(Hyperplane)是什么?
算法·机器学习·支持向量机·超平面·hyperplane
星空下的曙光8 小时前
React 虚拟 DOM Diff 算法详解,Vue、Snabbdom 与 React 算法对比
vue.js·算法·react.js
♞沉寂8 小时前
数据结构——双向链表
数据结构·算法·链表
大阳1238 小时前
数据结构2.(双向链表,循环链表及内核链表)
c语言·开发语言·数据结构·学习·算法·链表·嵌入式
CUC-MenG9 小时前
2025牛客多校第六场 D.漂亮矩阵 K.最大gcd C.栈 L.最小括号串 个人题解
c语言·c++·算法·矩阵
2401_876221349 小时前
Tasks and Deadlines(Sorting and Searching)
c++·算法