题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2152
题目大意:有n种水果,lcy要买m个。每一个水果有一个购买的下限和上限。问有多少种购买方案?
思路:体积都设置为1就好了。
#include<bits/stdc++.h>
#define LL long long
using namespace std;
//n*p*logn
struct Function{
int n1[20005], n2[20005], v[20005];
int a[20005], b[20005];
int getfun(int k, int p){//物品数 组成p的方案数
memset(a, 0, sizeof(int)*(p+1));
a[0]=1;
int last=0;
for(int i=1; i<=k; i++){
int last2=min(last+n2[i]*v[i], p);
memset(b, 0, sizeof(int)*(last2+1));
for(int j=n1[i]; j<=n2[i]&&j*v[i]<=last2; j++){
for(int k=0; k<=last&&k+j*v[i]<=last2; k++){
b[k+j*v[i]]+=a[k];
}
}
memcpy(a, b, sizeof(int)*(last2+1));
last=last2;
}
return a[p];
}
}fun;
int main() {
int n, m;
while(~scanf("%d%d", &n, &m)){
for(int i=1; i<=n; i++){
scanf("%d%d", &fun.n1[i], &fun.n2[i]);
fun.v[i]=1;
}
printf("%d\n", fun.getfun(n, m));
}
return 0;
}

京公网安备 11010502036488号