【bzoj1042】硬币购物
容斥
#include<bits/stdc++.h>
#define N 100005
typedef long long ll;
using namespace std;
ll ans,f[N];
int c[],d[],T;
void dfs(int x,int k,int sum){
if(sum<)return;
if(x==){
if(k&)ans-=f[sum];
else ans+=f[sum];
return ;
}
dfs(x+,k+,sum-(d[x]+)*c[x]);
dfs(x+,k,sum);
}
inline int read(){
int f=,x=;char ch;
do{ch=getchar();if(ch=='-')f=-;}while(ch<''||ch>'');
do{x=x*+ch-'';ch=getchar();}while(ch>=''&&ch<='');
return f*x;
}
int main(){
for(int i=;i<=;i++)c[i]=read();
T=read();f[]=;
for(int i=;i<=;i++)for(int j=c[i];j<=;j++)f[j]+=f[j-c[i]];
while(T--){
for(int i=;i<=;i++)d[i]=read();
int x=read();ans=;
dfs(,,x);
printf("%lld\n",ans);
}
return ;
}
【bzoj1042】硬币购物的更多相关文章
- bzoj1042硬币购物
		
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1042 dp预处理+容斥原理. 先预处理求出无限制的各面值的组成方案数 f (完全背包). 求s ...
 - bzoj1042硬币购物——递推+容斥
		
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1042 递推,再用容斥原理减掉多余的,加上多减的……(dfs)即可. 代码如下: #includ ...
 - [bzoj1042]硬币购物
		
先预处理出没有上限的方案数,然后容斥,然后将所有东西的范围都变为[0,+oo),即可用预处理出的dp数组计算 1 #include<bits/stdc++.h> 2 using names ...
 - BZOJ1042 [HAOI2008]硬币购物  完全背包  容斥原理
		
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1042 题目概括 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了t ...
 - 【BZOJ1042】硬币购物(动态规划,容斥原理)
		
[BZOJ1042]硬币购物(动态规划,容斥原理) 题面 BZOJ Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬 ...
 - [bzoj1042][HAOI2008][硬币购物] (容斥原理+递推)
		
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法. Input 第一 ...
 - 【BZOJ-1042】硬币购物       容斥原理 + 完全背包
		
1042: [HAOI2008]硬币购物 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1811 Solved: 1057[Submit][Stat ...
 - bzoj1042: [HAOI2008]硬币购物
		
#include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...
 - 【BZOJ1042】【DP + 容斥】[HAOI2008]硬币购物
		
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法. Input 第一 ...
 - BZOJ1042:[HAOI2008]硬币购物(DP,容斥)
		
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法. Input 第一 ...
 
随机推荐
- RMQ问题+ST算法
			
一.相关定义 RMQ问题 求给定区间的最值: 一般题目给定许多询问区间. 常见问题:对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n),返回数列A中下标在i,j之间的最小/大 ...
 - (转载)Linux进程间通信
			
(在学习linux进程通信,看到一篇很好的文章,转载过来,原文地址是http://www.cnblogs.com/linshui91/archive/2010/09/29/1838770.html) ...
 - PostgreSQL 建库建表脚本
			
1.创建角色(create_role.sql) drop role if exists "kq_acs";create role "kq_acs" login ...
 - 山科 STUST OJ Problem B: 编写函数:String to Double (II) (Append Code)
			
这道题没啥别的毛病,我的错误在于看不懂题. 另外还有一点是注意浮点数存在-0 #include <stdio.h> #include <ctype.h> #include &l ...
 - PhoneGap & HTML5 学习资料网址
			
PhoneGap 与 Application Cache应用缓存 http://www.html5cn.org/forum.php?mod=viewthread&tid=40272 加速We ...
 - Linux 常用命令记录(学习笔记)
			
不同机器间文件传输(转自:http://www.zhimengzhe.com/mac/323324.html) scp是什么? scp是secure copy的简写,用于在Linux下进行远程拷贝文件 ...
 - Java23个设计模式的简明教程
			
设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 毫无疑问,设计模式于 ...
 - Laravel中Redis的使用
			
安装 laravel中使用redis首先需要你通过 Composer 安装 predis/predis 包: composer require predis/predis 配置 redis的配置文件是 ...
 - 安装全局webpack
			
npm ls webpack 和npm ls webpack -g 查看本地和全局版本 npm install webpack@1.15.0 -g 全局 然后到项目里面 npm install npm ...
 - [Leetcode] String to integer atoi  字符串转换成整数
			
Implement atoi to convert a string to an integer. Hint: Carefully consider all possible input cases. ...