POJ 1252 Euro Efficiency

POJ 1252 Euro Efficiency

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

背包 要么 BFS

意大利是说给你几个基本的货币,组成 1~100 所有货币,使用基本上的货币量以最小的。

出口 用法概率。和最大使用量。

能够BFS 有可能 。

只是记得数组开大点。 可能会出现 100 = 99+99 -98 的情况。

背包是先做一个全然背包,求得最少可能由多少相加。

然后做一个 01背包,看是否能被 减。

背包:

#include<cstdio>
#include<cstring>
#include<string>
#include<queue>
#include<algorithm>
#include<map>
#include<stack>
#include<iostream>
#include<list>
#include<set>
#include<cmath>
#define INF 0x7fffffff
#define eps 1e-6
#define LL long long
using namespace std;
int dp[10002];

int value[7];

int main()
{
    int t;
    scanf("%d",&t);
    while(t--)
    {
        int m=10001;
        for(int i=0; i<6; i++)
            scanf("%d",&value[i]);
        for(int i=1; i<m; i++)
            dp[i]=10001;
        dp[0]=0;
        for(int i=0; i<6; i++)
        {
            for(int j=value[i]; j+value[i]<m; j++)
            {
                dp[j]=min(dp[j-value[i]]+1,dp[j]);
//                printf("%d :%d==\n",j,dp[j]);
            }

        }

        for(int i=0; i<6; i++)
        {
            for(int j=m-value[i]; j>0; j--)
            {
                dp[j]=min(dp[j+value[i]]+1,dp[j]);
//                printf("%d :%d==\n",j,dp[j]);
            }

        }

        double ans=0;
        int maxn=0;
        for(int i=1; i<=100; i++)
        {
//            printf("%d : %d\n",i,dp[i]);
            ans+=dp[i];
            maxn=max(maxn,dp[i]);
        }
        printf("%.2f %d\n",ans/100.0,maxn);
    }
}

BFS:

#include<cstdio>
#include<cstring>
#include<string>
#include<queue>
#include<algorithm>
#include<map>
#include<stack>
#include<iostream>
#include<list>
#include<set>
#include<cmath>
#define INF 0x7fffffff
#define eps 1e-6
#define LL long long
using namespace std;
struct lx
{
    int ans,lv;
};
int ans[2051];
int value[7];
void bfs()
{
    queue<lx>q;
    bool vis[2051];
    memset(vis,0,sizeof(vis));
    lx now,tmp;
    tmp.ans=0,tmp.lv=0;
    q.push(tmp);
    vis[0]=1;
    while(!q.empty())
    {
        tmp=q.front();q.pop();
        ans[tmp.ans]=tmp.lv;
        for(int i=0;i<6;i++)
        {
            int num1=tmp.ans+value[i];
            int num2=tmp.ans-value[i];
            now.lv=tmp.lv+1;
            if(!vis[num1]&&num1>0&&num1<2000)
            {
                vis[num1]=1;
                now.ans=num1;
                q.push(now);
            }
            if(!vis[num2]&&num2>0&&num2<2000)
            {
                vis[num2]=1;
                now.ans=num2;
                q.push(now);
            }
        }
    }
}
int main()
{
    int t;
    scanf("%d",&t);
    while(t--)
    {
        for(int i=0; i<6; i++)
            scanf("%d",&value[i]);

        bfs();
        double an=0;
        int maxn=0;
        for(int i=1;i<=100;i++)
        {
            an+=ans[i];
            maxn=max(maxn,ans[i]);
//            printf("%d : %d\n",i,ans[i]);
        }
        printf("%.2f %d\n",an/100,maxn);
    }
}

版权声明:本文博客原创文章。博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117264.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 分布式微服务架构的优缺点_单体架构和微服务架构

    分布式微服务架构的优缺点_单体架构和微服务架构单体架构、分布式架构、微服务优缺点单体架构特点?简单方便,高度耦合,扩展性差,适合小型项目。eg:学生管理系统。分布式架构特点?松耦合,扩展性好,但架构复杂,难度大。适合大型互联网项目,eg:京东、淘宝微服务:一种良好的分布式架构方案*优点:拆分粒度更小、服务更独立、耦合度更低*缺点:架构非常复杂,运维、监控、部署难度提高…

    2025年5月26日
    0
  • 软件测试(2) UFT安装

    软件测试(2) UFT安装1.QTP/UFT11.5(安装和破解)Quicktestprofessional(QTP/UFT)11.5官方版(含汉化包)下载地址:http://www.ddooo.com/softdown/63985.htm该网页中有 QTP无限试用教程具体百度网盘:http://pan.baidu.com/s/1hrTydRQ2.UFT12参考:http

    2022年5月12日
    42
  • 十进制小数转二进制小数方法

    十进制小数转二进制小数方法十进制小数转二进制小数方法转自:http://www.cnblogs.com/upzone/articles/1389365.html十进制小数→→→→→二进制小数 方法:“乘2取整”对十进制小数乘2得到的整数部分和小数部分,整数部分既是相应的二进制数码,再用2乘小数部分(之前乘后得到新的小数部分),又得到整数和小数部分.如此不断重复,直到小数部分为0或达到精度要求为止

    2022年9月24日
    0
  • FPGA实现CAN接口(SJA1000)

    FPGA实现CAN接口(SJA1000)学无止境,善于积累,每天积累一点点,成功就在眼前,加油!1CAN总线简介CAN(ControllerAreaNetwork,控制器局域网)总线是一个多主机异步串行总线,也是国际上应用最广泛的现场总线之一。在现场总线中,它是惟一被ISO国际标准化组织批准的现场总线。由于其成本低、容错能力强、支持分布式控制、通信速率高等优点在汽车、工业控制、航天等领域得到广泛应用。特别是由于CAN总线具有…

    2022年6月29日
    33
  • PyCharm与Python的安装教程2021.11

    PyCharm与Python的安装教程2021.11文章预览:一、进入官网下载PyCharm安装包二、等待下载完成后点击进行安装三、Python安装(只介绍最新版本)四、第一个PyCharm程序五、PyCharm安装第三方库方法一、进入官网下载PyCharm安装包自行进入PyCharm官网或点击https://www.jetbrains.com/pycharm/download/#section=windows下载的是社区版,免费并且足够使用。二、等待下载完成后点击进行安装1.点击next2.选择自己要安装的目录3.勾选一些设定(1

    2022年8月28日
    4
  • c语言中的offset_c语言中/和%的区别

    c语言中的offset_c语言中/和%的区别今天看libPhenom源代码,看到他们使用的JSON解析库参考的是JanssonJSON解析库。于是就去网上查了这个库,找到了官方网站:http://www.digip.org/jansson/。找了一下发现在Github上能够下载源代码,于是下载了源代码来瞅瞅。    看了一会儿发现有一块代码一直看不明白,就比如说如下的代码:json_t*json_object(void)

    2022年8月22日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号