問題の説明は
レレは大きな収穫を得る、TTの専門家の指導のために、収穫の季節に到着しました。特に果物、レレはおいしい味が、また素敵に見えないだけ...... Nの果物、りんご、梨、バナナ、スイカの合計を植えました。
だから、多くの人がレレ買い果物を見つけるためにここに来ます。でも有名なHDU ACM宗JiaotouのLCYが
来ました。LCYダース百ドル札を投げ、「私はMからなる果実のフルーツの盛り合わせを購入したいが、私は、それぞれの果実に、私は多くの制限を持っているため、それが一定の値より小さくすることはできません、小さな要求を持っています一定値を超えることはできません。と私は同じ2枚のプラッタを望んでいない。あなたはミックスと一致し、あなたは、私はコピーの多くを購入する方法を、多くの異なるプログラムを設定することができます! "
あなたは助けレレを喜ばせるだろう、彼はカウントヘルプ最後のカウントLCYに販売することができフルーツの盛り合わせの何人前。
果実は基本単位はもはや分裂が可能であることに注意してください。果物の品種の数が同じであれば、両方のプログラムについては、2つのプログラムが同じです。
レレは最終的にお金を取って、〜の彼の研究を続けることができます入力は、このタイトルは、ファイルの終わり(EOF)に対処するために、テストの複数のセットを持っています。各テストの最初の行は、N及びM(タイトル意味、0 <N、M <=説明を参照してください2つの正の整数を含む 100)
行当たり次情報N果実の行は、2つの整数A、B(0 <= A <= B <= 100) 、 AがBに対して少なくとも果実、アップ購入のみ果物を購入することができ表します。各試験の出力は、プログラム出力の数は、1ライン分の合計を販売することができます。答えは、情報主体であることを確認することです未満10 ^ 9
サンプルインプット
2 3
1 2
1 2
3 5
0 3
0 3
0 3サンプル出力
2
12
#include<stdio.h>
#include<string.h>
//#include <stdbool.h>
#include <algorithm>
#include<queue>
using namespace std;
//HDU2152Fruit 首先是需要有一个结构体来存储最大值和最小值
//这题和那些之前的区别在于 首先第一项的(Xmin Xmax) 然后第二项也是 (Xmin Xmax)
//先创建一个结构体
struct f{
int mmin;
int mmax;
}F[100];
int main()
{
int c[100];
int temp[100];
int n,m;//分别代表水果的种类和水果的数量
int i,j,k;
while(scanf("%d%d",&n,&m)!=EOF){
//再输入每种类型的最大值和最小值
for(i=1;i<=n;i++){
scanf("%d%d",&F[i].mmin,&F[i].mmax);
}
//对第一个数值赋初值,先初始化
memset(temp,0,sizeof(temp));
memset(c,0,sizeof(c));
for(i=F[1].mmin;i<=F[1].mmax;i++){
c[i]=1;
}
//然后就开始两项相乘,从第二项开始
for(i=2;i<=n;i++){
for(j=0;j<=m;j++){//这是前面一项,之前有个疑点,为什么这里j要从0开始,而不是j代表第一位,从F[1].mmin开始,那是因为当第一项和第二项产生乘积之后
//会出现一些原本在第一项中系数为0的次数变成系数不为0,也就是生成新系数 比如 x1*x2=x3
for(k=F[i].mmin;k<=F[i].mmax&&k+j<=m;k++){//这是后面一项
temp[k+j]+=c[j];
}
}
//开始对每一组进行存入最终数据
for(j=0;j<=m;j++){
c[j]=temp[j];
temp[j]=0;
}
}
printf("%d\n",c[m]);//到时候输入这个次数下的系数
}
}