OpenJudge-百练-2755

这道题用递归写的话还是很好写的,我们设递归函数的名称为Ways(w,k) 。

它的含义就是,w的大小,取k个物品,有多少种方式。

我们可以知道递归的边界条件就是当w的大小为0的时候,我们的方法数只有一种,但是当我们要取0个物品的时候,我们的方法数就为0了,因为Ways(40,0),显然是0。

边界条件知道以后,我们就可以知道对于物品k来说,我们有两种策略,一种是选它,一种是不选,我们把总的方案数加起来就可以了。

所以不选的时候,我们就让k-1,选的时候我们就让k-1,然后w-a[k]。

程序如下:

#include <iostream>
using namespace std;
int a[30],N;

int Ways(int w,int k)
{
	if (w==0)
		return 1;
	if (k<=0)
		return 0;
	return Ways(w,k-1)+Ways(w-a[k],k-1);
}

int main()
{
	cin>>N;	
	for (int i=1;i<=N;i++) {
		cin>>a[i];
	}
	cout<<Ways(40,N)<<endl;
	return 0;
}

 

posted @   xyee  阅读(81)  评论(0编辑  收藏  举报
编辑推荐:
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
阅读排行:
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· PPT革命!DeepSeek+Kimi=N小时工作5分钟完成?
· What?废柴, 还在本地部署DeepSeek吗?Are you kidding?
· 赶AI大潮:在VSCode中使用DeepSeek及近百种模型的极简方法
· DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
点击右上角即可分享
微信分享提示
主题色彩