• 洛谷 P2737 [USACO4.1]麦香牛块Beef McNuggets Label:一点点数论 && 背包


    题目描述

    农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块。奶牛们正在想尽一切办法让这种可怕的设想泡汤。奶牛们进行斗争的策略之一是“劣质的包装”。“看,”奶牛们说,“如果你只用一次能装3块、6块或者10块的三种包装盒包装麦香牛块,你就不可能满足一次只想买1、2、4、5、7、8、11、14或者17块麦香牛块的顾客了。劣质的包装意味着劣质的产品。”

    你的任务是帮助这些奶牛。给出包装盒的种类数N(1<=N<=10)和N个代表不同种类包装盒容纳麦香牛块个数的正整数(1<=i<=256),输出顾客不能用上述包装盒(每种盒子数量无限)买到麦香牛块的最大块数。如果所有购买方案都能得到满足或者不存在不能买到块数的上限,则输出0。 不能买到的最大块数(倘它存在)不超过2,000,000,000。

    输入输出格式

    输入格式:

    第1行: 包装盒的种类数N

    第2行到N+1行: 每个种类包装盒容纳麦香牛块的个数

    输出格式:

    输出文件只有一行数字:顾客不能用包装盒买到麦香牛块的最大块数或0(如果所有购买方案都能得到满足或者顾客不能买到的块数没有上限)。

    输入输出样例

    输入样例#1:
    3
    3
    6
    10
    输出样例#1:
    17

    说明

    题目翻译来自NOCOW。

    USACO Training Section 4.1

    代码

     1 #include<iostream>
     2 #include<cstring>
     3 #include<cstdio>
     4 #include<algorithm>
     5 #include<cstdlib>
     6 #define MAXN 100005
     7 using namespace std;
     8 
     9 int a[100];
    10 bool f[MAXN];
    11 int N,ul=MAXN-9000;
    12 
    13 int main(){
    14 //    freopen("01.in","r",stdin);//freopen("01.out","r",stdout);
    15     
    16     scanf("%d",&N);
    17     for(int i=1;i<=N;i++) {
    18         scanf("%d",&a[i]);
    19         if(a[i]==1){puts("0");return 0;}
    20     }
    21     sort(a+1,a+N+1);
    22     
    23     
    24     f[0]=1;    
    25     for(int k=1;k<=N;k++){
    26         for(int i=a[k];i<=ul;i++){
    27             f[i]=f[i]||f[i-a[k]];
    28         }
    29     }
    30     
    31     int x=0;
    32     for (int i=70000;i>=0;i--)
    33         if (f[i]==0){x=i;break;}
    34         
    35     if (x>65024) x=0;
    36     
    37     cout<<x<<endl;
    38     
    39     fclose(stdin);fclose(stdout);return 0;
    40 }

    以上为AC代码

    之前应为Line 35炸了,有一个点没过

    看题解吧:

    //出解范围256^2=65536--因为题目中的数据都是小于等于256的,所以如果有最大无法表示的数,必然小于256^2

    //可以采用构造法

    //对于无限解:

    // (1)输入数据中有1

    // (2)某个大于256^2的数不能被合成且这个数字一定小于等256^2+256=65792。

    版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 3.0 许可协议。转载请注明出处!
  • 相关阅读:
    类与类之间的几种关系
    spring之BeanFactory
    java打开本地应用程序
    java笔记六:线程间的协调
    继承与组合的优缺点
    适配器模式之对象适配器
    java笔记三:List接口
    java笔记二:final关键字用法总结
    设计模式之命令模式
    利用栈实现迷宫的求解
  • 原文地址:https://www.cnblogs.com/radiumlrb/p/6052319.html
Copyright © 2020-2023  润新知