Luogu2737 USACO4.1麦香牛块(动态规划)

  小凯的疑惑升级版。只有两个数的话不能表示的最大数是ab-a-b,显然如果可选数增加不会比这更大,所以只要答案存在一定小于256*256-2*256。在这个范围内背包即可。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
int read()
{
    int x=0,f=1;char c=getchar();
    while (c<‘0‘||c>‘9‘) {if (c==‘-‘) f=-1;c=getchar();}
    while (c>=‘0‘&&c<=‘9‘) x=(x<<1)+(x<<3)+(c^48),c=getchar();
    return x*f;
}
#define N 12
int n,a[N];
bool f[70000];
int main()
{
#ifndef ONLINE_JUDGE
    freopen("cow.in","r",stdin);
    freopen("cow.out","w",stdout);
    const char LL[]="%I64d\n";
#else
    const char LL[]="%lld\n";
#endif
    n=read();
    for (int i=1;i<=n;i++) a[i]=read();
    f[0]=1;
    for (int j=1;j<70000;j++)
        for (int i=1;i<=n;i++)
        if (j>=a[i]) f[j]|=f[j-a[i]];
    if (!f[69999]) {cout<<0;return 0;}
    for (int i=69999;i>=0;i--) if (!f[i]) {cout<<i;return 0;}
    cout<<0;
    return 0;
}

原文地址:https://www.cnblogs.com/Gloid/p/9867135.html

时间: 2024-10-10 17:37:05

Luogu2737 USACO4.1麦香牛块(动态规划)的相关文章

[Luogu2737] [USACO4.1]麦香牛块Beef McNuggets

题目描述 农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是“劣质的包装”.“看,”奶牛们说,“如果你只用一次能装3块.6块或者10块的三种包装盒包装麦香牛块,你就不可能满足一次只想买1.2.4.5.7.8.11.14或者17块麦香牛块的顾客了.劣质的包装意味着劣质的产品.” 你的任务是帮助这些奶牛.给出包装盒的种类数N(1<=N<=10)和N个代表不同种类包装盒容纳麦香牛块个数的正整数(1&

P2737 [USACO4.1]麦香牛块Beef McNuggets(完全背包+数论确定上界)

题目链接:https://www.luogu.org/problem/show?pid=2737 题目大意:农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是“劣质的包装”.“看,”奶牛们说,“如果你只用一次能装3块.6块或者10块的三种包装盒包装麦香牛块,你就不可能满足一次只想买1.2.4.5.7.8.11.14或者17块麦香牛块的顾客了.劣质的包装意味着劣质的产品.” 你的任务是帮助这些奶牛

洛谷——P2737 [USACO4.1]麦香牛块Beef McNuggets

https://www.luogu.org/problemnew/show/P2737 题目描述 农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是“劣质的包装”.“看,”奶牛们说,“如果你只用一次能装3块.6块或者10块的三种包装盒包装麦香牛块,你就不可能满足一次只想买1.2.4.5.7.8.11.14或者17块麦香牛块的顾客了.劣质的包装意味着劣质的产品.” 你的任务是帮助这些奶牛.给出包装

P2737 [USACO4.1]麦香牛块Beef McNuggets

题目描述 农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是“劣质的包装”.“看,”奶牛们说,“如果你只用一次能装3块.6块或者10块的三种包装盒包装麦香牛块,你就不可能满足一次只想买1.2.4.5.7.8.11.14或者17块麦香牛块的顾客了.劣质的包装意味着劣质的产品.” 你的任务是帮助这些奶牛.给出包装盒的种类数N(1<=N<=10)和N个代表不同种类包装盒容纳麦香牛块个数的正整数(1&

NOIP2017总结 &amp; 题解

day1t1的结论貌似在哪见过,自己稍微验证了一下貌似没记错就没有管了.t2一道很好(keng)的模拟题t3自己做题好慢啊,想出来dp打上去最后几分钟才过了大样例,我写的是记忆化搜索,判-1很好判,没时间加上去了可惜了,不过还是自己做题太慢了.然后由于没拍,不确定自己dp对不对,就特判了k=0粘了一个暴力,没想到暴力错了,70变成50...基础不扎实gg 100+100+50=250  好菜啊t3没A掉 day2t1看完题就开始打,没注意算距离时减一下就变成两倍了会爆long long,但好像数

牛场围栏(vijos 1054)

题目大意: 给出N种木棍(每种木棍数量无限)的长度(<=3000),每根木棍可以把它切掉[1,M]的长度来得到新的木棍. 求最大的不能被组合出来的长度. 如果任何长度都能组合出来或者最大值没有上限输出-1.    (1<N<100, 0<=M<3000), 解题过程: 1.这题就是USACO 4.1的麦香牛块 ,只不过 数据 加强了下. 当时就把它当做 背包 来做,然后确定一个较大的范围(当时就选了60000),求出这个范围里的长度能否都被组合出来,如果能就输出-1. 否则输

NOIP2017旅游(过节)总结

又到了一年一度的N(光)O(棍)I(节) (搞得我双十一没买东西) 初评Noverber 20$^{th}$才出. 开始BB Day 0 早上运动会入场式.(穿着像韩服的汉服,还和五六个班撞了,巨尴尬,幸好我们第二个入场) 搞定之后,回宿舍收拾东西.(明明中午一堆时间,也不知到自己为什么那么Stupid,把唯一的一张批条用掉了,可能学习了某部番的"猴氏智减法") "猴氏智减法"链接,看傻人不赔钱 然后到机房学习.(FU BAI) 下午4:00 走掉了,都不知道三饭有

Python Mongo数据库

目录 1.mongo的安装 2.mongo数据库操作 3.Python与Mongo交互 1. mongo的安装 (将安装目录下的bin目录添加到系统环境变量中) # mongo的配置: 1.创建数据库文件及日志文件目录, 并将目录写入配置文件 2.在系统终端执行以下命令: mongod --bind_ip 127.0.0.1 --logpath "D:\Professional\MongoDB\log\mongodb.log" - -logappend --dbpath "D

USACO4.1.1--Beef McNuggets

chunlvxiong的博客 题目描述: 有N种包装盒(1≤N≤10),每种包装盒可以包装牛块i块(1≤i≤256),每种包装盒可以使用任意次.求无法包装的最大的牛块数,若所有数目的牛块都能被包装,或者无法包装的最大牛快数为oo,那么输出0. 思考&分析: 其实这是个数论问题--给定N个数,求不能由这些数通过加减得到的最大数. 如果只有两个数,那么这个问题比较经典,也存在如下结论:若gcd(p,q)==1 ,则px+qy不能表示的最大数为pq-p-q. 如果N个数中没有任何两个数的GCD==1的