bzoj-2287___POJ Challenge —— 删除背包

2023-11-02 11:08

本文主要是介绍bzoj-2287___POJ Challenge —— 删除背包,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:传送门(原题目好像在OJ上消失了,真是诡异)

题目大意:

  简单的背包,问第 i i i个物品消失( i i i 1 1 1 n n n),装满容积为 x x x的背包的方案数( x x x 1 1 1 m m m),输出 i i i m m m的矩阵

解题思路:

  一开始简单的想从 1 1 1遍历到 n n n去算第 i i i个物品消失的影响,但在仔细一想发现不对经。后来想了一下发现应该用再用一次dp来优化复杂度,即先求出物品不消失的所有背包方案数,然后再遍历依次求每个物品消失时,背包方案数。

代码思路:

  先01背包套个模板,然后物品依次消失的时候,这里和01背包思想不一样
   ① ① 当容量 j < w [ i ] j<w[i] j<w[i]时,很明显总方案数就是当前容量 j j j的方案数
   ② ② 但当容量 j > = w [ i ] j>=w[i] j>=w[i]时,当前容量 j j j的方案数就等于总方案数 − - 容量 j − w [ i ] j-w[i] jw[i]的方案数
  这样来判断时,我们的容量 j j j就要从 1 1 1遍历到 m m m,因为每次转移时要从没有这个物品的状态转移

核心:很经典的双重dp,理解好了可以加深dp的思想

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 2e3 + 5;
int n, m;
int w[maxn], v[maxn];
int dp[maxn][maxn], all[maxn];int main() {scanf("%d%d", &n, &m);for(int i=0; i<n; i++)scanf("%d", &w[i]);memset(dp, 0, sizeof(dp));for(int i=0; i<n; i++) {all[0] = 1;for(int j=m; j>=w[i]; j--) {all[j] += all[j - w[i]];all[j] %= 10;}}for(int i=0; i<n; i++) {dp[i][0] = 1;for(int j=1; j<=m; j++)if(j>=w[i]) {dp[i][j] = all[j] - dp[i][j-w[i]] + 10;dp[i][j] %= 10;} else {dp[i][j] = all[j];}}for(int i=0; i<n; i++) {for(int j=1; j<=m; j++)printf("%d", dp[i][j]);printf("\n");}
}

这篇关于bzoj-2287___POJ Challenge —— 删除背包的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/330182

相关文章

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Redis过期键删除策略解读

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,... 目录1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略1.1惰性删除策略

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C