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)
上一篇 2022年1月8日 下午2:00
下一篇 2022年1月8日 下午2:00


相关推荐

  • 怪盗基德的滑翔翼(最长上升子序列)「建议收藏」

    怪盗基德的滑翔翼(最长上升子序列)「建议收藏」最长上神子序列(nlogn)原题链接怪盗基德是一个充满传奇色彩的怪盗,专门以珠宝为目标的超级盗窃犯。而他最为突出的地方,就是他每次都能逃脱中村警部的重重围堵,而这也很大程度上是多亏了他随身携带的便于操作的滑翔翼。有一天,怪盗基德像往常一样偷走了一颗珍贵的钻石,不料却被柯南小朋友识破了伪装,而他的滑翔翼的动力装置也被柯南踢出的足球破坏了。不得已,怪盗基德只能操作受损的滑翔翼逃脱。假设城市中一共有N幢建筑排成一条线,每幢建筑的高度各不相同。初始时,怪盗基德可以在任何一幢建筑的顶端。他可以选择一个

    2022年8月8日
    7
  • 外企入职第一封英文邮件_投外企要英文简历吗

    外企入职第一封英文邮件_投外企要英文简历吗   一份出色的Resume,是向外企求职的关键之一。不了解有关的常识和程式,不花费相当的心思来展示,以有纯正娴熟的英文功底,决不能获得单位的青睐。在一大堆错误百出、英文表达能力低劣或平庸,毫无针对性和创造性的Resume中,你的那份若能让人眼睛一亮,成功的机会必将大大增加,以下试着结合一个具体的例子给出说明和评述。   BalanceSheet:  基本方法选取适当的工作后,必须看清

    2022年10月20日
    4
  • ubuntu cuda卸载干净_ubuntu18安装cuda10

    ubuntu cuda卸载干净_ubuntu18安装cuda10cd/usr/local/cuda/bin sudo./cuda-uninstaller (根据cuda版本不同,名称略有不同)

    2025年9月19日
    9
  • 使用iframe框架时,子页面内跳转整个页面

    使用iframe框架时,子页面内跳转整个页面由于开发需要 很多时候需要使用到 iframe 框架 即子页面 子页面使用是挺方便的 但如果子页面呢需要跳转整个页面呢 比如我就遇到了一个问题 我子页面有个功能需要登录 所以连接的是登录页面 但登录页面只在子页面中显示 这就显得很不合理了 在这里 我介绍几种方法 第一种 是比较大众的方法 及子页面内标签的整个页面跳转 只需在标签中添加 target parent 即可 第二种是在 head

    2026年3月18日
    2
  • linux网络编程学习笔记之五 —–并发机制与线程�

    linux网络编程学习笔记之五 —–并发机制与线程�

    2021年11月29日
    47
  • 腾讯元宝尝鲜版(AI助手) v1.0.12 免费安装版

    腾讯元宝尝鲜版(AI助手) v1.0.12 免费安装版

    2026年3月13日
    4

发表回复

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

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