Balance POJ - 1837 计数dp

传送门


题目大意:有一个天平, 平衡臂上有C个钩子, (ci < 0 表示在左边, ci > 0 表示钩子在右边,  值表示距离终点的长度)。 然后是G个砝码的重量,  要求所有的砝码都用上,求使天平平衡的方案有多少种。

解题思路:W[i] 表示第i个砝码的重量, L[i]保存每个钩子的位置。

要求挂i个砝码平衡时有多少中, 那就是加上这个砝码之前这个臂上少多少力。 dp[i][j] 表示挂上i个砝码的时候的状态, j<0 表示向右偏, 即左边缺少多少牛力。  j>0即表示右边缺少多少牛的力, 由于数组下标不能是负的, 我们可以让最小的情况为0, 则中点即 最大的可能 mid = 20 * 20 * 15;   右边的都大于mid, 左边的都小于 mid。

因此状态转移方程:dp[i][j + w[i] * L[k]] = dp[i-1][j]


代码:

#include <iostream>
#include <cstdio>
#include <cstring>

using namespace std;
const int mid = 20 * 20 * 15;
const int rig = mid*2;
int dp[25][rig + 5];
int L[25], W[25];
int main()
{
	int n, m;
	while(~scanf("%d%d", &n, &m))
	{
		for(int i=0; i<n; ++i) scanf("%d", &L[i]);
		for(int i=0; i<m; ++i) scanf("%d", &W[i]);
		memset(dp, 0, sizeof dp);
		dp[0][mid] = 1;
		for(int i=1; i<=m; ++i)
			for(int k = 0; k<n; ++k)
				for(int j = 0; j <= rig; ++j)
					//if(j + W[i]*L[k] >=0 && j + W[i]*L[k] <= rig)
					if(dp[i-1][j])
						dp[i][j+W[i-1]*L[k]] += dp[i-1][j];
		cout << dp[m][mid] <<endl;
	}
	return 0;
}


基于STM32的循迹避障小车资料源码(高分项目),个人大四的毕业设计、经导师指导并认可通过的高分设计项目,评审分99分,代码完整确保可以运行,小白也可以亲自搞定,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(高分项目)基于STM32的循迹避障小车资料源码(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值