关闭

POJ 1837 Balance(01背包)

174人阅读 评论(0) 收藏 举报
分类:

Description
有一个天平,两个臂上有钩子,臂长15,给出所有钩子的位置,给出每个钩码的重量(各不相同),求必须使用所有钩码的前提下,有多少种平衡方法
Input
第一行为两个整数n和m分别表示钩子个数和钩码个数(2<=C,G<=20),第二行为钩子位置,第三行为钩码质量
Output
输出平衡方法种数
Sample Input
2 4
-2 3
3 4 5 8
Sample Output
2
Solution
a[i]表示钩子位置,b[i]表示钩子质量,dp[i][j]表示用前i个砝码到达力矩j的方法数
dp[i ][j+a[k]*b[i]]+=dp[i-1][j];
Code

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
#define maxn 21
#define maxv 15000
typedef long long ll;
ll n,m;
ll a[maxn],b[maxn];
ll dp[maxn][maxv];
int main()
{
    while(scanf("%d%d",&n,&m)!=EOF)
    {
        memset(dp,0,sizeof(dp));
        dp[0][maxv/2]=1;//不挂钩码中心位置平衡 
        int i,j,k;
        for(i=1;i<=n;i++)
            scanf("%d",&a[i]);
        for(i=1;i<=m;i++)
            scanf("%d",&b[i]);
        for(i=1;i<=m;i++)//m个钩码 
            for(j=1;j<=maxv;j++)//一个钩码只能用一次 
                if(dp[i-1][j])//判断前一状态是否存在 
                    for(k=1;k<=n;k++)//将这个钩码分别钩在n个钩子上 
                        dp[i][j+a[k]*b[i]]+=dp[i-1][j];
        printf("%d\n",dp[m][maxv/2]);//令中心位置平衡的种类数 
    }
    return 0;
}
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:353577次
    • 积分:19504
    • 等级:
    • 排名:第448名
    • 原创:1663篇
    • 转载:0篇
    • 译文:0篇
    • 评论:60条
    最新评论