消失之物(背包DP)(容斥或分治)
容斥做法:
首先n^2搞出f[i][j]第i个物品,j体积的方案数。
去除每个物品贡献:
设个g[i][j]表示当i不选,j体积方案数(注意不是此时的范围相对于全局,而不是1---i)
那么我们用到一些容斥的思想
g[i][j]=f[n][j]-g[i][j-w[i]]
因为g[i][j-w[i]]即可表示当i选时的方案数(都是相对于全局的)
而且注意枚举顺序,我们要用当前g[i]的状态更新之后个g[i]的状态,
而且在j<w[i]的情况下g[i][j]=f[n][j]
注意取模.....
1 #include<map>
2 #include<iostream>
3 #include<cstdio>
4 #include<cstring>
5 #include<algorithm>
6 #include<cmath>
7 #include<string>
8 #include<vector>
9 #define MAXN 4101
10 #define int long long
11 using namespace std;
12 int f[MAXN][MAXN];
13 int g[MAXN][MAXN];
14 int n=0,w[MAXN];
15 int sum=0;
16 signed main()
17 {
18 scanf("%lld%lld",&n,&sum);
19 for(int i=1;i<=n;++i)
20 {
21 scanf("%lld",&w[i]);
22 }
23 f[0][0]=1;
24 for(int i=1;i<=n;++i)
25 {
26 for(int j=sum;j>=0;--j)
27 {
28 f[i][j]=f[i-1][j];
29 }
30 for(int j=sum;j>=w[i];--j)
31 {
32 f[i][j]=(f[i][j]+f[i-1][j-w[i]]+10)%10;
33 }
34 }
35 for(int i=1;i<=n;++i)
36 {
37 for(int j=0;j<=w[i]-1;++j)
38 {
39 g[i][j]=(f[n][j]+10)%10;
40 }
41 for(int j=w[i];j<=sum;++j)
42 {
43 g[i][j]=(f[n][j]-g[i][j-w[i]]+10)%10;
44 }
45 }
46 for(int i=1;i<=n;++i)
47 {
48 for(int j=1;j<=sum;++j)
49 {
50 printf("%lld",(g[i][j]+10)%10);
51 }
52 printf("\n");
53 }
54 }
分治:
%%%%skyh,非常强的思路
我们按照分治的做法,其实每一次我们只是不选其中的一件物品,其余不变,
那么我们利用这个性质,只用除了自身以外的物品更新当前答案
让我们想起树的结构,把叶子节点当作询问,
只需要每次递归左右区间,查询叶子节点时,左右都已经更新答案
回溯时重新更新
1 #include<iostream>
2 #include<cstdio>
3 #define int short
4 using namespace std;
5 const int N=2010;
6 int n,m,w[N],dp[15][N];
7 inline void add(int &a,int b){
8 a+=b;
9 if(a>=10) a-=10;
10 }
11 void solve(int dep,int l,int r){
12 if(l==r){
13 for(int i=1;i<=m;++i) printf("%hd",dp[dep-1][i]);
14 puts("");
15 return ;
16 }
17 int mid=l+r>>1;
18 for(int i=0;i<=m;++i) dp[dep][i]=dp[dep-1][i];
19 for(int i=mid+1;i<=r;++i) for(int j=m;j>=w[i];--j) add(dp[dep][j],dp[dep][j-w[i]]);
20 solve(dep+1,l,mid);
21 for(int i=0;i<=m;++i) dp[dep][i]=dp[dep-1][i];
22 for(int i=l;i<=mid;++i) for(int j=m;j>=w[i];--j) add(dp[dep][j],dp[dep][j-w[i]]);
23 solve(dep+1,mid+1,r);
24 }
25 signed main(){
26 scanf("%hd%hd",&n,&m);
27 for(int i=1;i<=n;++i) scanf("%hd",&w[i]);
28 dp[0][0]=1; solve(1,1,n);
29 return 0;
30 }
%%%skyh
消失之物(背包DP)(容斥或分治)的更多相关文章
- [Luogu P1450] [HAOI2008]硬币购物 背包DP+容斥
题面 传送门:https://www.luogu.org/problemnew/show/P1450 Solution 这是一道很有意思的在背包里面做容斥的题目. 首先,我们可以很轻松地想到暴力做背包 ...
- BZOJ 2287: 【POJ Challenge】消失之物( 背包dp )
虽然A掉了但是时间感人啊.... f( x, k ) 表示使用前 x 种填满容量为 k 的背包的方案数, g( x , k ) 表示使用后 x 种填满容量为 k 的背包的方案数. 丢了第 i 个, 要 ...
- 【bzoj2287】[POJ Challenge]消失之物 背包dp
题目描述 ftiasch 有 N 个物品, 体积分别是 W1, W2, ..., WN. 由于她的疏忽, 第 i 个物品丢失了. “要使用剩下的 N - 1 物品装满容积为 x 的背包,有几种方法呢? ...
- BZOJ2287: 【POJ Challenge】消失之物(背包dp)
题意 ftiasch 有 N 个物品, 体积分别是 W1, W2, ..., WN. 由于她的疏忽, 第 i 个物品丢失了. “要使用剩下的 N - 1 物品装满容积为 x 的背包,有几种方法呢?” ...
- bzoj 3622 DP + 容斥
LINK 题意:给出n,k,有a,b两种值,a和b间互相配对,求$a>b$的配对组数-b>a的配对组数恰好等于k的情况有多少种. 思路:粗看会想这是道容斥组合题,但关键在于如何得到每个a[ ...
- 【BZOJ 4665】 4665: 小w的喜糖 (DP+容斥)
4665: 小w的喜糖 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 94 Solved: 53 Description 废话不多说,反正小w要发喜 ...
- BZOJ 2287 【POJ Challenge】消失之物(DP+容斥)
2287: [POJ Challenge]消失之物 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 986 Solved: 572[Submit][S ...
- [LOJ#3119][Luogu5405][CTS2019]氪金手游(DP+容斥)
先考虑外向树的做法,显然一个点在其子树内第一个出现的概率等于它的权值除以它子树的权值和.于是f[i][j]表示i的子树的权值和为j时,i子树内所有数的相互顺序都满足条件的概率,转移直接做一个背包卷积即 ...
- HDU 5838 (状压DP+容斥)
Problem Mountain 题目大意 给定一张n*m的地图,由 . 和 X 组成.要求给每个点一个1~n*m的数字(每个点不同),使得编号为X的点小于其周围的点,编号为.的点至少大于一个其周围的 ...
随机推荐
- PHP 下载apk文件
方式一.public function downApkFile(){ $path = Env::get('root_path')."apk/"; //路径 $file_name = ...
- Linux下为Calibre书库打中文目录名与文件名补丁
本文由来 临近下班突然看到知乎上有篇文章是给Calibre打中文目录与文件名补丁的,想起我之前为啥放弃Calibre的--存进书库里书的名称都变成了拼音!手动找起来或者搜索工具找起来太麻烦了(有时想不 ...
- c#log4net简单好用的配置
新建文件log4net.config 编辑文件log4net.config <configuration> <configSections> <!--日志记录--> ...
- Linux性能调优命令之free
功能说明 free 命令显示系统使用和空闲的内存情况,包括物理内存.交互区内存(swap)和内核缓冲区内存.共享内存将被忽略 语法 free [参数] 参数 -b : 以Byte为单位显示内存使用情况 ...
- 重新整理 .net core 实践篇————依赖注入应用[二]
前言 这里介绍一下.net core的依赖注入框架,其中其代码原理在我的另一个整理<<重新整理 1400篇>>中已经写了,故而专门整理应用这一块. 以下只是个人整理,如有问题, ...
- 一文搞懂:java中的VO、PO、BO、DAO、POJO
针对java工程里的各种带O的对象,进行分析,了解各自的作用. PO:persistent object,持久对象.与数据库里表字段一一对应.PO是一些属性,以及set和get方法组成.一般情况下,一 ...
- RHEL_高级磁盘管理(vdo、stratis)
RHEL高级磁盘管理-VDO VDO简介 Virtual Data Optimizer 通过数据去重.压缩的方式来优化存储空间. VDO层放置在现有块存储设备上,例如Raid设备.本地磁盘设备. LV ...
- shell脚本 在后台执行de 命令 >> 文件 2>&1 将标准输出与错误输出共同写入到文件中(追加到原有内容的后面)
命令 >> 文件 2>&1或命令 &>> 文件 将标准输出与错误输出共同写入到文件中(追加到原有内容的后面) # ll >>aaa 2> ...
- Ansible命令行方式执行
Ansible ad-hoc 什么是ad-hoc? 临时命令,执行完不会保存,类似于批量执行命令. ansible的选项 -i # 指定主机清单 ansible rsync -m ping -i 1. ...
- visual studio code 快捷键-(转自 浅笑千寻)
Visual Studio Code之常备快捷键 官方快捷键大全:https://code.visualstudio.com/docs/customization/keybindings Visual ...