POJ-1837-Balance-DP
2016-01-18 22:38
309 查看
http://poj.org/problem?id=1837
题目大意:
有一个天平,天平左右两边各有若干个钩子,总共有C个钩子,有G个钩码,求将钩码全部挂到钩子上使天平平衡的方法的总数。
其中可以把天枰看做一个以x轴0点作为平衡点的横轴
本题的状态方程 是根据 平衡度来转移....
即dp[i][j]表示 前i物品都用上,得到 j的平衡度,平衡度为0表示平衡,>0表示右偏,<0偏左
dp[i][j+c[k]*g[i]]=dp[i-1][j] 表示在dp[i-1][j],前i-1个物品在某种摆放方案下得到j的平衡度, 那么直接在cc[k]的位置挂上一个物品i,就可以得到 dp[i][j+c[k]*g[i]]的平衡度对应的方案数
由于下标不能为负数,最大的平衡度 为 15*20*25=7500,我们设之为 平衡原点,那么j:1-15k
初始化 只需要 dp[0][7500]=1;
for (i=1;i<=g;i++)
{
for (j=0;j<=15000;j++)
{
if (dp[i-1][j]==0) continue;
for (k=1;k<=c;k++)
{
dp[i][j+cc[k]*gg[i]]+=dp[i-1][j];
}
}
}
ac
#include <cstdio>
#include <cmath>
#include <cstring>
#include <string>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <vector>
#include <iostream>
using namespace std;
const double pi=acos(-1.0);
double eps=0.000001;
int cc[25],gg[25];
int dp[22][15050];
int main()
{
int c,g;
int i,j,k;
cin>>c>>g;
for (i=1;i<=c;i++)
scanf("%d",&cc[i]);
for (i=1;i<=g;i++)
scanf("%d",&gg[i]);
// for (i=0;i<=7500*2;i++)
dp[0][7500]=1;
for (i=1;i<=g;i++)
{
for (j=0;j<=15000;j++)
{
if (dp[i-1][j]==0) continue;
for (k=1;k<=c;k++)
{
dp[i][j+cc[k]*gg[i]]+=dp[i-1][j];
}
}
}
printf("%d\n",dp[g][7500]);
return 0;
}
题目大意:
有一个天平,天平左右两边各有若干个钩子,总共有C个钩子,有G个钩码,求将钩码全部挂到钩子上使天平平衡的方法的总数。
其中可以把天枰看做一个以x轴0点作为平衡点的横轴
本题的状态方程 是根据 平衡度来转移....
即dp[i][j]表示 前i物品都用上,得到 j的平衡度,平衡度为0表示平衡,>0表示右偏,<0偏左
dp[i][j+c[k]*g[i]]=dp[i-1][j] 表示在dp[i-1][j],前i-1个物品在某种摆放方案下得到j的平衡度, 那么直接在cc[k]的位置挂上一个物品i,就可以得到 dp[i][j+c[k]*g[i]]的平衡度对应的方案数
由于下标不能为负数,最大的平衡度 为 15*20*25=7500,我们设之为 平衡原点,那么j:1-15k
初始化 只需要 dp[0][7500]=1;
for (i=1;i<=g;i++)
{
for (j=0;j<=15000;j++)
{
if (dp[i-1][j]==0) continue;
for (k=1;k<=c;k++)
{
dp[i][j+cc[k]*gg[i]]+=dp[i-1][j];
}
}
}
ac
#include <cstdio>
#include <cmath>
#include <cstring>
#include <string>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <vector>
#include <iostream>
using namespace std;
const double pi=acos(-1.0);
double eps=0.000001;
int cc[25],gg[25];
int dp[22][15050];
int main()
{
int c,g;
int i,j,k;
cin>>c>>g;
for (i=1;i<=c;i++)
scanf("%d",&cc[i]);
for (i=1;i<=g;i++)
scanf("%d",&gg[i]);
// for (i=0;i<=7500*2;i++)
dp[0][7500]=1;
for (i=1;i<=g;i++)
{
for (j=0;j<=15000;j++)
{
if (dp[i-1][j]==0) continue;
for (k=1;k<=c;k++)
{
dp[i][j+cc[k]*gg[i]]+=dp[i-1][j];
}
}
}
printf("%d\n",dp[g][7500]);
return 0;
}
相关文章推荐
- HDU 3743 (树状数组,离散化)
- 51.Rxjava+RxAndroid+Retrofit组合问题
- BGP maximum-path实验(一)
- CocoaAsyncSocket 文档3:介绍GCDAsyncSocket
- jenkins 入门教程(上)
- JMeter源码集成到Eclipse
- Eclipse按哪个组合键可以自动添加import里面的包啊?
- 深入比较ThreadLocal模式与synchronized关键字
- s_重载匹配
- MIME(多用途Internet的邮件扩展)
- 2016/1/18 单例模式 预习 例题
- 无法建立SSL连接
- C语言之反序数组和求最大值和最小值
- Spring注解:@Responsebody与@RequestBody
- 手工注入简记
- Relevancy 3.1 搜索相关性探究
- 迭代加深搜索(埃及分数)
- 【android基础三】Android中SQLite应用详解
- 基于live555的一个简单RTSP服务器
- ubutnu 下SVN 提交时忽略某些文件或文件夹