代码随想录训练营Day41

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

今天是跟着代码随想录刷题的第41天,主要是学习了二维背包和一维背包还有分割等和子集的代码


提示:以下是本篇文章正文内容,下面案例可供参考

一、二维背包

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void printDP(const vector<vector<int>>& dp) {
    for (const auto& row : dp) {
        for (int val : row) {
            cout << val << " ";
        }
        cout << endl;
    }
}
void wcy(){
    vector<int> weight={1,3,4};
    vector<int> value={15,20,30};
    int i,j;
    int bagspace=4;
    vector<vector<int>> dp(weight.size(),vector<int>(bagspace+1,0));
    for(j=weight[0];j<bagspace+1;j++)
    {
        dp[0][j]=value[0];
    }
    for(i=1;i<weight.size();i++)
    {
        for(j=1;j<bagspace+1;j++)
        {
            if(j<weight[i]) dp[i][j]=dp[i-1][j];
            else
            {
                dp[i][j]=max(dp[i-1][j],dp[i-1][j-weight[i]]+value[i]);
            }
        }
    }
    // 打印dp数组
    cout << "DP array:" << endl;
    printDP(dp);

    // 输出背包容量为bagspace时的最大价值
    cout << "Maximum value for bagspace " << bagspace << ": " << dp[weight.size()][bagspace] << endl;

}
int main() {
    wcy();
    return 0;
}

二、一维背包

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void printDP(const vector<int>& dp) {
    for (int val : dp) {
        cout << val << " ";
    }
    cout << endl;
}

void wcy(){
    vector<int> weight={1,3,4};
    vector<int> value={15,20,30};
    int i,j;
    int bagspace=4;
    vector<int> dp(bagspace+1,0);
    for(j=weight[0];j<bagspace+1;j++)
    {
        dp[j]=value[0];
    }
    for(i=1;i<weight.size();i++)
    {
        for(j=bagspace;j>=weight[i];j--)
        {
            dp[j]=max(dp[j],dp[j-weight[i]]+value[i]);
        }
    }
    // 打印dp数组
    cout << "DP array:" << endl;
    printDP(dp);

    // 输出背包容量为bagspace时的最大价值
    cout << "Maximum value for bagspace " << bagspace << ": " << dp[bagspace] << endl;

}
int main() {
    wcy();
    return 0;
}




---

# 三、分割等和子集
思路:就是0-1背包的问题,主要就是背包的重量和价值是一样的情况

```cpp
class Solution {
public:
    bool canPartition(vector<int>& nums) {
    int sum=0;
    for(int i=0;i<nums.size();i++)
    {
        sum=sum+nums[i];    
    }
    if(sum%2==1) return false;
    sum=sum/2;
    vector<int> dp(sum+1,0);
    for(int j=nums[0];j<sum+1;j++)
    {
        dp[j]=nums[0];
    }
    for(int i=1;i<nums.size();i++)
    {
        for(int j=sum;j>=nums[i];j--)
        {
            dp[j]=max(dp[j],dp[j-nums[i]]+nums[i]);
            if(dp[j]==sum) return true;
        }
    }
    return false;

    }
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值