hdu 3348 coins

这道题算是一道很经典的题,很好的诠释了贪心和动态规划的不同功能。求最少钱的数量用贪心就够了,但是求最多钱的数量要用到动态规划的思想,每步都尽量保留最大

数量。具体看程序注解:

复制代码
#include"iostream"
#include"stdio.h"
#include"algorithm"
#include"string.h"
#include"cmath"
using namespace std;
int fewest(int a[],int num[],int price)
{
    int i;
    int ans=0;
    for(i=5;i>1;i--)
    {
        if(price>=num[i]*a[i])
        {
            ans+=num[i];
            price-=num[i]*a[i];
        }
        else
        {
            ans+=price/a[i];
            price%=a[i];
        }
    }
    if(price>num[1])return -1;
    else return ans+price;
}
//这个函数的整体思想就是先保留全部的小钱,用大钱补缺,这样就可以得到最大数量
int largest(int a[],int num[],int price)
{
    int i;
    int ans=0;
    int sum[6];
    sum[1]=num[1];
    for(i=2;i<6;i++)
    {
        sum[i]=sum[i-1]+a[i]*num[i];
    }
    for(i=5;i>1;i--)
    {
        if(price<=sum[i-1])continue;
        else
        {
            int t;
            //先用满足条件的最大面值,如果有余数,所用张数+1,
            //不足的部分用较小面值的进行补
            t=((price-sum[i-1])/a[i])+(((price-sum[i-1])%a[i])?1:0);
            ans+=t;
            price-=t*a[i];
        }
    }
   return ans+price;
}
int main()
{
    int t,price,i,j;
    int a[6]={0,1,5,10,50,100};//面值
    int num[6];//数量
    cin>>t;
    while(t--)
    {
        cin>>price;
        int sum=0;
        for(i=1;i<=5;i++)
            {
                cin>>num[i];
                sum+=num[i]*a[i];
            }
        if(sum<price) {cout<<"-1 -1"<<endl;continue;}
        int mi=fewest(a,num,price);
        if(mi==-1) {cout<<"-1 -1"<<endl;continue;}
        int mx=largest(a,num,price);
        cout<<mi<<" "<<mx<<endl;
    }
    return 0;
}
View Code
复制代码

 

posted @   Run_For_Love  阅读(161)  评论(0编辑  收藏  举报
编辑推荐:
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
· SQL Server如何跟踪自动统计信息更新?
· AI与.NET技术实操系列:使用Catalyst进行自然语言处理
阅读排行:
· 官方的 MCP C# SDK:csharp-sdk
· 一款 .NET 开源、功能强大的远程连接管理工具,支持 RDP、VNC、SSH 等多种主流协议!
· 提示词工程师自白:我如何用一个技巧解放自己的生产力
· 一文搞懂MCP协议与Function Call的区别
· 如何不购买域名在云服务器上搭建HTTPS服务
点击右上角即可分享
微信分享提示