开心的小明

经过修改后的代码:

/*
功能:

输入参数:int*p 指向二维数组的首地址,该二维数组第0行的两个数分别表示:总钱数<30000,和希望购买物品的个数<25;
          该数组从第1行到第m行(1<=j<=m)中给出了编号为j的物品的基本数据,每行有2个非负整数,
		  表示该物品的价格(<=10000)和该物品的重要度(1~5)。

		  GetResult表示不超过总钱数的物品的价格与重要度乘积的总和的最大值(<100000000)。

		  不需做入参检查,测试用例可以保证~
		  
    例如:4000 8(第0行)
		  821 3  (第1行)
		  422 5
		  458 5
		  500 3
		  200 2
		  430 4
		  530 3
		  239 3
		 
		  则表示 总钱数为4000,希望购买物品个数为8个,因此从第1行到第8行表示编号为j的物品的价格及物品的重要度。
	 	
          

	 		
返回值:无

温馨提示:根据题意可知,该二维数组只有两列,且行数为第0行的第二个元素数值+1;入参p不能按照二维数组的方法来取值,要将
          二维的转换成一维的哦~

*/

void GetResult(int* p,int& result)
{	 
    //	在这里实现功能
    result = 0;
    if (NULL == p)
    {
        return;
    }

    int totle_money = p[0]; //总钱数
    int num = p[1];  //个数
    int *pValues = new int[num];
    int *pWeight = new int[num];

    for (int i = 2, j = 0; i <= num*2; i += 2,j++)
    {
        pValues[j] = p[i];
        pWeight[j] = p[i+1];
        //std::cout<<pValues[j]<<" "<<pWeight[j]<<std::endl;
    }

    int pp[30000];
    memset(pp, 0, sizeof(pp)); 
    for (int l = 0; l < num; l++)
    {
        for (int k = totle_money; k >= pValues[l]; k--)  
        {  
            int temp = pp[k-pValues[l]] + pValues[l]*pWeight[l];  
            if (temp > pp[k])
            {
                pp[k] = temp;
            }
        }
    }

    result = pp[totle_money];
    delete [] pValues;
    delete [] pWeight;
    return; 
} 


http://blog.csdn.net/chao887062/article/details/7588979

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值