题解 | #放苹果#

放苹果

http://www.nowcoder.com/practice/4f0c1e21010e4d849bde5297148e81d9

#include <cstdio>
#include <string>
#include <algorithm>

using namespace std;

//求m个苹果放n个盘子中的方法数
int ways(int m, int n) {
	//边界条件
	if (m == 0)return 1;
	if (n == 0)return 0;
	/*m<n时,必定有n-m个盘子空着,去掉它们不影响摆放数目。
m>=n时,分两种情况:至少有一个盘子空着;所有盘子都有苹果,从每个盘子中拿一个苹果不影响放法。*/
	if (m < n) {
		return ways(m, m);
	}
	else {
		return ways(m, n - 1) + ways(m - n, n);
	}
}
int main() {
	int M, N;
	while (cin >> M >> N) {
		cout << ways(M, N) << endl;
	}

	return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
05-14 20:34
门头沟学院 Java
窝补药贝八股:管他们,乱说,反正又不去,直接说680
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务