Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 6383 Accepted Submission(s): 4787 Problem Description 又到了选课的时间了,xhd看着选课表发呆,为了想让下一学期好过点,他想知道学n个学分共有多少组合。你来帮帮他吧。(xhd认为一样学分的课没区别)
Input 输入数据的第一行是一个数据T,表示有T组数据。
Output 对于每组输入数据,输出一个整数,表示学n个学分的组合数。
Sample Input 2 2 2 1 2 2 1 40 8 1 1 2 2 3 2 4 2 5 8 6 9 7 6 8 8
Sample Output 2 445
Author xhd
Source ACM程序设计期末考试_热身赛(感谢 xhd & 8600)
Recommend lcy | We have carefully selected several similar problems for you: 2082 2110 2152 2189 2078 |
思路:就套一下母函数的模板就行了,基本没啥变化的
代码:
#include<iostream>
#include<cstring>
#include<cstdio>
#define N 50
using namespace std;
int a[N],b[N],i,j,k,last,last2,v[50],n[50],p,num;
int main()
{
int t;
cin>>t;
while(t--)
{
cin>>p>>num;
for(i=1;i<=num;i++)
cin>>v[i]>>n[i];
memset(a,0,sizeof(a));
a[0]=1;
for(int i=1;i<=num;i++)
{
memset(b,0,sizeof(b));
for(int j=0;j<=n[i]&&j*v[i]<=p;j++)
for(int k=0;k+j*v[i]<=p;k++)
b[k+j*v[i]]+=a[k];
memcpy(a,b,sizeof(b));
}
cout<<a[p]<<endl;
}
return 0;
}