int[V + 1][T + 1] opt; // 子问题的记录项表,假设从i到T种饮料中,
// 找出容量总和为V'的一个方案,满意度最多能够达到
// opt(V',i,T-1),存储于opt[V'][i],
// 初始化时opt中存储值为-1,表示该子问题尚未求解。
int Cal(int V, int type)
{
if(type == T)
{
if(V == 0)
return 0;
else
return -INF;
}
if(V < 0)
return -INF;
else if(V == 0)
return 0;
else if(opt[V][type] != -1)
return opt[V][type]; // 该子问题已求解,则直接返回子问题的解;
// 子问题尚未求解,则求解该子问题
int ret = -INF;
for(int i = 0; i <= C[type]; i++)
{
int temp = Cal(V – i * C[type], type + 1);
if(temp != -INF)
{
temp += H[type] * i;
if(temp > ret)
ret = temp;
}
}
return opt[V][type] = ret;
}
C++编程之美-代码清单1-10
原创
©著作权归作者所有:来自51CTO博客作者wx5d0241bb88268的原创作品,请联系作者获取转载授权,否则将追究法律责任
代码清单1-10
上一篇:C++经典算法题-费式数列
下一篇:C++经典算法题-骑士走棋盘
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
C++编程之美-代码清单1-17
代码清单1-17#define BUFFER_COUNT 100
c++ 算法 #define