笔试编程练习20190825

此题为限定质量和体积情况下,求反应堆中能够产生的最大能量。
实质上是一个二维0-1背包问题,利用动态规划求解。

/**
 *Copyright @ 2019 Zhang Peng. All Right Reserved.
 *Filename:
 *Author: Zhang Peng
 *Date:
 *Version:
 *Description:
**/

#include<iostream>
#include<vector>
#include<algorithm>

using namespace std;

int maxEnergyGenerate(int reactorCap, int numberOfRadLiquid, int criticalMass, int *volumes, int *messes, int *energies)
{
	vector<vector<int >> dp(reactorCap + 1, vector<int >(criticalMass + 1, 0));
	//int ** dp = new int*[reactorCap + 1];
	//for (int i = 0; i < reactorCap + 1; i++)
	//{
	//	dp[i] = new int[criticalMass + 1];
	//	for (int j = 0; j < criticalMass + 1; j++)
	//		dp[i][j] = 0;
	//	//memset(dp[i], 0, sizeof(dp)*(criticalMass + 1));
	//}
	for (int i = 0; i < numberOfRadLiquid; i++)
	for (int j = reactorCap; j >= volumes[i]; j--)
	for (int k = criticalMass; k >= messes[i]; k--)
		dp[j][k] = max(dp[j][k], dp[j - volumes[i]][k - messes[i]] + energies[i]);

	int result = dp[reactorCap][criticalMass];
	return result;
}



int main() {
	int v = 100, q = 15, m = 5;  //v 最大体积 q最大质量 m物品数量
	//vol 存放各个物品的体积 qua存放各个物品的质量 value存放各个物品的价值
	int  vol[55] = { 50,40,30,20,10}, qua[55] = { 1,2,3,9,5}, value[55] = { 300,480,270,200,180 };
	
	std::cout << "最大价值: " << maxEnergyGenerate(v,m,q,vol,qua,value) << std::endl;
	
	system("pause");
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值