题解 | #神奇的口袋#

神奇的口袋

https://www.nowcoder.com/practice/9aaea0b82623466a8b29a9f1a00b5d35

#include <cstdio>
#include <iostream>
using namespace std;

int arr[20];
int dp[40];

int main() {
    int n;
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }
    for (int i = 0; i < 40; i++) {
        dp[i] = 0;
    }

    for (int i = 0; i < n; i++) {
        for (int j = 40; j >= arr[i]; j--) {
		  // 动态转移方程 第j个坑位 保存的是 第j个坑位 + 第 [j - nums[i]] 个坑位的和
            dp[j] = dp[j] + dp[j - arr[i]];
        }
        dp[arr[i]]++;
    }
    printf("%d", dp[40]);
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
zYvv:双一流加大加粗再标红,然后广投。主要是获奖荣誉不够,建议开始不用追求大厂,去别的厂子刷下实习。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务