Charm Bracelet

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
const int maxm = 12880 + 5;
const int maxn = 3402 + 5;
int F[maxn][maxm];  //F[i][j]表示前j个物品重量为i的的最大权重  看样子要使用滚动数组
int N, M;
struct node{
	int w, d;
}s[maxn];

void pre() {
	memset(F, 0, sizeof(F));
	for(int i = 1; i <= N; i++) 
		for(int j = 1; j <= M; j++){
			if(j >= s[i].w) {  //这个条件非常重要   要仔细点儿 
				F[i][j] = max((F[i-1][j-s[i].w]+s[i].d), F[i-1][j]);
			}
			else 
				F[i][j] = F[i-1][j];
		}
}


int main() {
	cin >> N >> M;
	for(int i = 1; i <= N; i++) {
		cin >> s[i].w >> s[i].d;
	} 
	pre();
	cout << F[N][M] << endl;
	return 0;
}


//======使用滚动数组=============// 

#include<iostream>
#include<cstring>
using namespace std;
const int maxm = 12880 + 5;
const int maxn = 3402 + 5;
int F[maxm];  //F[i][j]表示前j个物品重量为i的的最大权重  看样子要使用滚动数组
int N, M;
struct node{
	int w, d;
}s[maxn];

void pre() {
	memset(F, 0, sizeof(F));
	for(int i = 1; i <= N; i++) 
		for(int j = M; j >= 1; j--){
			if(j >= s[i].w) {  //这个条件非常重要   要仔细点儿 
				F[j] = max((F[j-s[i].w]+s[i].d), F[j]);
			}
		}
}


int main() {
	cin >> N >> M;
	for(int i = 1; i <= N; i++) {
		cin >> s[i].w >> s[i].d;
	} 
	pre();
	cout << F[M] << endl;
	return 0;
}


//======使用滚动数组 + 优化输入 + 优化空间=============// 

#include<iostream>
#include<cstring>
using namespace std;
const int maxm = 12880 + 5;
const int maxn = 3402 + 5;
int F[maxm]; 
int N, M;
struct node{
	int w, d;
}s;

int main() {
	cin >> N >> M;
	memset(F, 0, sizeof(F));
	for(int i = 1; i <= N; i++) { 
		cin >> s.w >> s.d;
		for(int j = M; j >= 1; j--){
			if(j >= s.w) {  //这个条件非常重要   要仔细点儿 
				F[j] = max((F[j-s.w]+s.d), F[j]);
			}
		}
	}
	cout << F[M] << endl;
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值