HAOI 硬币购物
试题描述:
现在一共有4种硬币,面值各不相同,分别为ci(i=1,2,3,4)。某人去商店买东西,去了tot次,每次带di枚ci硬币,购买价值为si的货物。请问每次有多少种付款方法。
输入:
第一行包括五个数,分别为c1,c2,c3,c4和tot 接下来有tot行,每行五个数,第i+1行五个数依次为第i次购物所带四种硬币的数目和购买货物的价值(d1,d2,d3,d4,s )。各行的数两两之间用一个空格分隔。
输出:
tot行,依次为每次付款的方法数。
输入示例:
1 2 5 10 2
3 2 3 1 10
1000 2 2 2 900
输出示例:
4
27
数据范围:
0<di,s<=100000,0<tot<=1000。
这道题其实就是一个dp+容斥原理(不知道什么是容斥原理的自己上网百度去)……
首先我们先对于dp数组进行初始操作。我们定义:dp[i]是在不考虑硬币是否超限的情况下用硬币凑i元的方案数。这样我们就可以得到状态方程:dp[j]+=dp[j-c[i]](由数据发现我们的0<=j<=100000,1<=i<=4)注意:dp[0]=1
然后我们就可以进行容斥原理的操作。对于每种硬币,都有超和不超两种情况,所以最终我们只需要统计2^4=16次就够了。在记录状态的时候,我们可以用10进制的数来记录,可是在操作的时候其实是对2进制进行操作。举个例子:比如我用5记录了一种状态,5的二进制就是0101,其表达的意思就是第一种和第三种硬币超出了限度。
那么我们应该如何来表示使用硬币超过了限度?举个例子:比如当前第i种硬币有d[i]枚硬币可以用的话,如果我们用到了d[i]+1枚硬币那就是说我们用硬币超过了限度,且其他硬币是可以随意使用的,所以这样的情况应该有dp[s-c[i]*(d[i]+1)]种,如果s-c[i]*(d[i]+1)<0那方案数也就是0。其余的情况也类似。
这题是要开long long的,要不过不去……我就是这么死的……
AC代码:
#include<iostream>
#include<memory.h>
#include<stdio.h>
#include<cstdio>
#include<cctype>
using namespace std;
//--------------------------
void read(long long &x){
x=;char ch=getchar();long long f=;
for(;!isdigit(ch);ch=getchar())if(ch=='-')f=-;
for(;isdigit(ch);ch=getchar())x=x*+ch-'';
x*=f;
}
//---------------------------
long long c[],d[],s,tot,ans,cnt,sum,cur;
long long dp[+];
bool flag=;
int main(){
for(int i=;i<=;i++){
read(c[i]);
}
read(tot);
dp[]=;
for(int i=;i<=;i++){
for(int j=c[i];j<=;j++)dp[j]+=dp[j-c[i]];
}
while(tot--){
for(int i=;i<=;i++)read(d[i]);
read(s);
ans=;
for(int i=;i<;i++){
cnt=;sum=;cur=;
int t=i;
while(t>){
cur++;
if(t&)sum+=(d[cur]+)*c[cur],cnt++;
t>>=;
}
if(s<sum)continue;
if(cnt&)ans-=dp[s-sum];
else ans+=dp[s-sum];
}
printf("%lld\n",ans);
}
}
HAOI 硬币购物的更多相关文章
- [HAOI 2008]硬币购物
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 ...
- 【BZOJ】【1042】【HAOI2008】硬币购物
DP+容斥原理 sigh……就差一点…… 四种硬币的数量限制就是四个条件,满足条件1的方案集合为A,满足条件2的方案集合为B……我们要求的就是同时满足四个条件的方案集合$A\bigcap B\bigc ...
- 1042: [HAOI2008]硬币购物 - BZOJ
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法.Input 第一行 ...
- 【BZOJ1042】【DP + 容斥】[HAOI2008]硬币购物
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法. Input 第一 ...
- Bzoj 1042: [HAOI2008]硬币购物 容斥原理,动态规划,背包dp
1042: [HAOI2008]硬币购物 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1747 Solved: 1015[Submit][Stat ...
- bzoj 1042: [HAOI2008]硬币购物 dp+容斥原理
题目链接 1042: [HAOI2008]硬币购物 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1706 Solved: 985[Submit][ ...
- BZOJ 1042: [HAOI2008]硬币购物( 背包dp + 容斥原理 )
先按完全背包做一次dp, dp(x)表示x元的东西有多少种方案, 然后再容斥一下. ---------------------------------------------------------- ...
随机推荐
- Red Hat TimesTen安装记录
1:内核参数修改 # vi /etc/sysctl.conf kernel.sem= #sysctl –p 备注:此安装过程为测试环境,具体参数修改要参考TimesTen官方文档. 2:创建用户及组信 ...
- Qt一步一步实现插件调用(附源码)
最近手里几个项目都采用插件的方式进行开发工作,这里记录一下实现方法,给需要的同学一个参考, 在linux系统和window系统都能成功编译通过,不废话直接步骤 第一步:建立插件原型 新建一个Qt项目, ...
- java 上传图片 打水印
其实就是在现有的图片上,画东西,也可以直接 贴图片 //添加水印 @Override public File pressFile(File file,String press_path) throws ...
- POJ2084 Game of Connections(数学,dp)
题目链接. 分析: 简单的 Catalan 数 将x~y编号,设解为 d(x, y), d(x, y) = {d(x+1,i-1)*d(i+1,y)}, 其中 x+1<= i <= y, ...
- 【转】如何开启notepad++函数列表功能
原文网址:http://jingyan.baidu.com/article/4b07be3c41e05e48b380f3f6.html Notepad++是window下特有的一款开源编辑器软件,相信 ...
- VirtualBox - 自动调整屏幕大小,显示分辨率
在VirtualBox中安装了Ubuntu后,Ubuntu的屏幕调整不太好,操作起来非常不方便,需要安装Vbox的增强功能.具体如下:1, 在 设备--> 安装增强功能这时会自动加载VBOXA ...
- 非常全面的Linux知识点总结
$1 我的Linux需求 Linux博大精深.我只在此讨论一些我对线上Linux机器维护人员的基本需求,比如装机,加硬盘,配网络.只讨论CentOS 6,或者类似的RHEL,当然Ubuntu也可以此类 ...
- Flask-SQLAlchemy获取一个字段里去掉重复的数据
注意:可排序的列表内元素不可以是字典等复杂数据类型 比较容易记忆的是用内置的set l1 = ['b','c','d','b','c','a','a']l2 = list(set(l1))prin ...
- javascript基础笔记学习
/** * Created by Administrator on 2016/12/26. */ /* var box; alert( typeof box); box是Undefined类型,值是u ...
- Event Delivery: The Responder Chain(事件传递,响应链)
当我们设计app的时候,我们很可能想动态的响应事件.例如,触摸一个拥有许多不同对象的屏幕,你要决定给哪个对象一个响应事件,怎么样对象接收到事件. 当一个用户产生事件发生时(如 点击),UIKit产生一 ...