
题目链接:http://poj.org/problem?id=1664
m个相同的苹果放在n个相同的盘子里,有多少种不一样的方法。
当m < n 时,f(m,n) = f(m,m) 当m >= n 时,f(m,n) = f(m-n,n) + f(m,n-1)
终止条件: 苹果m = 1时,只有一种摆法 碟子n = 1时,只有一种摆法 m=n时,所有碟子都摆一个的摆法 f(m-n,n) = f(0,n) = 1

#include<iostream>
using namespace std;
unsigned long func(size_t apple, size_t disc)
{
if(apple == 1 || apple == 0 || disc == 1)
return 1;
if(apple < disc)
return func(apple, apple);
else
return func(apple, disc-1) + func(apple-disc, disc);
}
int main()
{
size_t t, apple, disc;
cin >> t;
while(t--)
{
cin >> apple >> disc;
cout << func(apple, disc) << endl;
}
return 0;
}