题目链接:km46. 携带研究材料
#include
#include
using namespace std;
int main(){
int M;
int N;
std::cin>>M>>N;
std::vector<int> space(M);
std::vector<int> value(M);
for(int i=0;i<M;i++){
std::cin>>space[i];
}
for(int i=0;i<M;i++){
std::cin>>value[i];
}
vector<vector<int>>dp(M,vector<int>(N+1,0));
for(int i =space[0];i<=N;i++){
dp[0][i]=value[0];//能装的情况下把物品1都装进去
}
for(int i =1;i<M;i++){
for(int j=0;j<=N;j++){
if(j<space[i])dp[i][j] = dp[i-1][j];//当前物品占用空间大于背包空间,装不了
else dp[i][j]=max(dp[i-1][j],dp[i-1][j-space[i]]+value[i]);//能装,把i物品需要空间的总价值减掉,再加上当前物品的价值,看看价值和不换哪个大
// std::cout<
}
// std::cout<
}
std::cout<<dp[M-1][N];
return 0;
}
题目链接:416. 分割等和子集
class Solution {
public:
bool canPartition(vector<int>& nums) {
int sum =0;
for(int &i :nums){
sum+=i;
}
if(sum%2==1)return false;
int target = sum/2;
vector<int>dp(100*100+1,0);
for(int i =0;i<nums.size();i++){
for(int j =target;j>=nums[i];j--){
dp[j]=max(dp[j],dp[j-nums[i]]+nums[i]);
}
}
if(dp[target]==target)return true;
return false;
}
};