开心的小明

小明要在规定金额内购买物品,要求物品的价格与重要度乘积的总和的最大值


#include"cstring"  
#include"stddef.h"
 
  
/*
功能:

输入参数: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的物品的价格及物品的重要度。   
 		
返回值:无
*/

void GetResult(int*p,int& Get_Result)
{	 
   //	在这里实现功能,用动态数组
    Get_Result = 0;  
    if (p==NULL)  
    {  
        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];  
    }  
  
    int pp[30000];              //总钱数<30000,存放在该剩余钱处 的价值
    memset(pp, 0, sizeof(pp)); 
   int temp;
 for (int l = 0; l < num; l++)         //物品个数
    {  
        for (int k = totle_money; k >= pValues[l]; k--)    //余钱与价格的限制
        {    
            temp = pp[k-pValues[l]] + pValues[l]*pWeight[l];    
            if (temp > pp[k])        //比较购买后与不购买的情况
            {  
                pp[k] = temp;  
            }  
        }  
    }  
  
    Get_Result= pp[totle_money];  
    delete [] pValues;  
    delete [] pWeight;  
    return;   
} 

	



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值