POJ 1664放苹果题解

POJ 1664 放苹果

看到这一题,第一眼就感觉是排列组合的问题。想起了高中老师给总结的分组问题,然后就陷入了死循环。看了讨论区,才明白,这只是一道很简单的递推题~

我们的关注点是苹果数最少的盘子里放了几个苹果,显然,有两种情况:

1,最少的盘子是空的,即0个苹果,那么此时,就相当于m个苹果放到n-1个篮子里

2,最少的盘子不是空的,假设有c个苹果,那么就可以先把所有盘子里放c个,剩下的m-n*c个苹果放到剩下的n-1个盘子里。懒得统计这个c是多少了,就可以直接用1来算,大不了减c次嘛~

所以,核心代码是:

int solve(int m, int n)//m个苹果放到n个篮子里~
{
    if(m < 0)   return 0;
    if(m == 0 || n == 1) return 1;
    return solve(m-n, n) + solve(m, n-1);
}


猜你喜欢

转载自blog.csdn.net/q1410136042/article/details/78127615