动态规划背包刷题

洛谷P1049装箱问题

cpp 复制代码
#include<iostream>
using namespace std;
int m, n;
const int N = 20005;
int v[35];
int dp[35][N];//装i个物品空间为j的盒子剩余空间最小的值
int main(){
	cin >> m >> n;
	for(int i = 1; i <= n; i++){
		cin >> v[i];
	}
	for(int i = 0; i < N; i++)dp[0][i] = i;
	for(int i = 1; i <= n; i++){
		for(int j = 0; j <= m; j++){
			if(j < v[i])dp[i][j] = dp[i - 1][j];//不够空间只能不装 
			else dp[i][j] = min(dp[i - 1][j], dp[i - 1][j - v[i]]);//空间够了可装可不装(找小的) 
		}
	}
	cout << dp[n][m] << endl;
	return 0;
}

洛谷P1060开心的金明

cpp 复制代码
#include<iostream>
using namespace std;
int n, m;
const int N = 30005, M = 30;
int v[M], w[M];
int dp[N];//dp[i][j]表示不超过j元的前i物品价格*重要度的最大值 
int main(){
	cin >> n >> m;
	for(int i = 1; i <= m; i++){
		cin >> v[i] >> w[i];
	}
	for(int i = 1; i <= m; i++){
		for(int j = n; j >= v[i]; j--){
			dp[j] = max(dp[j], dp[j - v[i]] + v[i] * w[i]);
		}
	}
	cout << dp[n] << endl;
	
	return 0;
}

洛谷P3985不开心的金明

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
int n, m;
const int N = 110, M = 1e8;
int v[N], w[N], maxx, minn = 0x3f3f3f3f;
long long dp[M];
bool cmp(int a, int b){
	return a > b;
}
int main(){
	cin >> n >> m;
	for(int i = 1; i <= n; i++){
		cin >> v[i] >> w[i];
		maxx = max(maxx, v[i]);
		minn = min(minn, v[i]);
	}
	if(minn <= 300){
		for(int i = 1; i <= n; i++){
			for(int j = m; j >= v[i]; j--){
				dp[j] = max(dp[j], dp[j - v[i]] + w[i]);
			}
		}
		cout << dp[m] << endl;
	}
	else{
		int ans = 0;
		sort(w + 1, w + n + 1, cmp);
		for(int i = 1; i <= m / minn; i++){
			ans += w[i];
		}
		cout << ans << endl;
	}
	
	return 0;
}

洛谷P2722总分 Score Inflation

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
int n, m;
const int N = 10010;
int mark[N], t[N];
long long dp[N]; 
int main(){
	cin >> m >> n;
	for(int i = 1; i <= n; i++){
		cin >> mark[i] >> t[i];
	}
	dp[0] = 0;
	for(int i = 1; i <= n; i++){
		for(int j = 1; j <= m; j++){
			if(t[i] <= j)dp[j] = max(dp[j], dp[j - t[i]] + mark[i]);
		}
	}
	cout << dp[m] << endl;
	
	return 0;
}
相关推荐
SsummerC2 分钟前
【leetcode100】杨辉三角
python·leetcode·动态规划
杰杰批3 分钟前
力扣热题100——普通数组(不普通)
算法·leetcode
CodeSheep3 分钟前
稚晖君又添一员猛将!
人工智能·算法·程序员
天天扭码5 分钟前
一分钟解决“3.无重复字符的最长字串问题”(最优解)
前端·javascript·算法
风靡晚10 分钟前
一种改进的CFAR算法用于目标检测(解决多目标掩蔽)
人工智能·算法·目标检测·目标跟踪·信息与通信·信号处理
香宝的最强后援XD24 分钟前
区域填充算法
算法
所以遗憾是什么呢?42 分钟前
扩展欧几里得算法【Exgcd】的内容与题目应用
数学·算法·数论·扩展欧几里得·exgcd
haaaaaaarry1 小时前
【贪心】C++ 活动安排问题
开发语言·c++·算法·贪心
ChengZUOZZZ1 小时前
蓝桥杯题目:二维前缀和
java·算法·蓝桥杯
槐月杰5 小时前
C语言中冒泡排序和快速排序的区别
c语言·算法·排序算法