麦香牛肉(dp 、数论)

麦香牛肉

时间限制: 1 Sec  内存限制: 128 MB

题目描述

农夫约翰的奶牛几乎要武装暴动,因为他们听说麦当劳要推出新产品麦香牛肉。奶牛们要尽力阻止这种产品的上市。他们研究了一种“劣等包装”策略。奶牛们说: “如果麦香牛肉有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行: 一个盒子里的牛肉数量。

注意,有多组数据输入

输出

输出题目中要求的单个整数。

样例输入

3
3 6 10

样例输出

17

提示

USACO 2002 Winter Orange

当第一次看到这个题目的时候,一点想法都没有。数据范围那么大,如果一个个的枚举过去,时间上肯定会暴,而且也没有实际意义。题目要求的是最大的不能买到的数量,也就是在题目提供的数据以任何方式组合都不能达到的最大数。我当时在考虑,怎么保证某一个很大数是可以通过题目提供的数据来组合。

我当时想着用一个数组存储提供数据的所有组合,但显然这样做不仅麻烦而且是错误的。

于是,在网上看了别人的说明:这是一道基本的DP题目。

// 如果输入的数据里面有 1  肯定就没有上界了;

//  如果输入的数据的最大公约数不为1,则没有上界;

//  数据最大 不会超过 max*max

有些点到目前还不是很理解,在此记录下来,以后慢慢再进行研究。以下是网上找到的数学证明:

由于数目非常庞大,不能简单进行动态规划,必须先进行数学分析缩小范围。此题进行数学抽象,给定n个正整数{an},于是有集合S={a1*x1+a2*x2+...+an*xn,xi属于N},求集合N-S 的属性,以下先从n=2 开始阐述。

引理1:S={a*x + b*y, x,y属于自然数N},当a、b 互素时,N-S为有限集,其最大值为 a*b-a-b;当a、b不互素时(a,b最大公约数大于1),则N-S 为无限集

证明:

(1) 当a、b不互素时(a,b最大公约数大于1),则N-S 为无限集

这个比较好证明,设p=gcd(a,b),则a*x+b*y必定可以写成 p*z 的形式,由于p>1,则p* z + 1必定不属于S,于是N-S 为无限集

(2) 当a、b互素时,则N-S 为有限集,且最大值为a*b-a-b

首先证明 a*b-a-b 不属于S,使用反证法,

a*b-a-b = a*x + b*y  => a*(b-1-x) = b*(1+y),由于 a、b互素,则有b-1-x>=b,这与定义矛盾,于是有a*b-a-b 必定不属于S

然后证明任何一个数z > a*b-a-b,均能表示为a*x + b*y(x,y属于N),令z=a*b-a-b+i,因为a、b互素,则i=a*m+b*n(m,n属于整数,不是自然数),于是z=a*(b-1+m) + b*(n-1),当m、n均不为负数时,z均可以表示为a*x+b*y的形式,下面证明m、n有一个为负数时的情况。

不失一般性,设i=a*x-b*y(x,y属于N),我们可以做一个变换,确保y<=a-1,当y>=a时,设y=a*r+s(s&lt;=a-1),则有i=a*x-b*(a*r+s) =a(x-br)-bs,即i表示为a*x-b*y时,可以确保y<=a-1,此时必有x>=1。

z=a*b-a-b+a*x-b*y = a(x-1) + b(a-1-y),由于 x>=1,y<=a-1,所以z可以表示,命题得证。

此命题表明S 包含大于等于ab-a-b+1的所有整数

引理2:S={a*x + b*y + c*z, x,y,z属于自然数N},当a、b、c互素时,N-S为有限集,其最大值不大于MAX(ab,ac,bc)

证明

如果其中有两个元素互素,比如gcd(a,b)=1,则由引理1得到N-S为有限集,其最大值必定不大于ab-a-b,即不大于MAX(ab,ac,bc)

假设任意两个元素均不互素,不失一般性,令ab=MAX(ab,ac,bc),p=gcd(a,b),于是有a*x+b*y+c*z=p*(a1*x+b1*y) + c*z,其中p和z互素,a1和b1互素,将a1*x+b1*y看作一个元素,运用引理1得到 N-S 的最大值为pc-p-c,但由于a1*x+b1*y从a1b1-a1-b1之后才开始连续,所以N-S的最大值必定小于pc-p-c+ p(a1b1-a1-b1) < pc + ab/p

只要证明pc + ab/p <ab即可,因为p>=2则ab/p<=ab/2,因为p<=a/2,c<b,则pc<ab/2,于是命题得证。

引理2的证明给我们提供了解决原问题的思路

定理:S={a1*x1+a2*x2+...+an*xn,xi属于N},当a1i,a2,...,an互素时,N-S的最大值小于MAX(ai) * MAX(ai)

使用数学归纳法证明,n=2,3时已经证明,假设n-1时已经证明,以下证明n时

如果其中有n-1个互素,则问题直接得证,即以下的证明为任意n-1个元素不互素的情况。不失一般性,假设n个数中a1和a2为最大的两个数,设p=gcd(a1,a2,...,an-1)

a1*x1+a2*x2+...+an*xn= p(a’1*x1+...+a’n-1*xn-1) + an*xn

根据归纳假设a’1*x1+...+a’n-1*xn-1至少从a’1a’2开始连续,且运用引理1,可以得到N-S最大值小于p an -p- an  +p(a’1 a’2) < p an+ (a1 a2)/2,利用与引理2相同的证明方法可以得到N-S的最大值小于a1a2

根据此定理,可以将原麦香牛块问题的范围限制到256*256之中,再使用动态规划求解就可行了。

原文地址:http://blog.csdn.net/wdq347/article/details/9313699

#include<bits/stdc++.h>
using namespace std;
bool a[70919];// 256*256
//a[i]=1表示i是能组合成的数
long long b[305];
int GCD(int a, int b){if(a % b)return GCD(b, a%b);else return b;
}    // 最大公约数int main()
{int n;while(cin>>n){bool ff=0;//标记有没有出现1 int gys;for(int i=1;i<=n;i++){cin>>b[i];if(b[i]==1){ff=1;}}gys=GCD(b[1],b[2]);for(int i=3;i<=n;i++){gys=GCD(gys,b[i]);//输入数据的最大公约数
        }if(ff||(gys!=1))// 如果输入有1 则没有上界{// 最大公约数>1 , 则没有上界cout<<0<<endl;continue;}memset(a,0,sizeof(a));//开始dp sort(b+1,b+1+n);//其实不排序也没有关系 a[0]=1;long long mm=b[n]*b[n];long long ma=0;long long mi=b[1];for(long long i=mi;i<=mm;i++){if(a[i]==1){continue;}for(long long j=1;j<=n;j++){if(i>=b[j]){if(a[i-b[j]]==1){//cout<<"已知"<<i-b[j]<<"能ok "<<i<<"也ok"<<endl; a[i]=1;ma=max(ma,i);}}}}//倒着找最大的不能组合成的数 bool f=1;long long kk=-1;for(long long i=mm;i>=1;i--){if(a[i]==0)//有不能组合成的数
            {f=0;kk=i;break;}}if(f==0){cout<<kk<<endl;}else{cout<<0<<endl;}            }return 0;
}

posted on 2019-05-31 10:44 蔡军帅_ACM 阅读(...) 评论(...) 编辑 收藏

麦香牛肉(dp 、数论)相关推荐

  1. 【USACO】【数论】【DP】 Chapter 4 Section 1,1麦香牛块题解

    题目 题目描述 农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是"劣质的包装" ...

  2. [USACO4.1]麦香牛块Beef McNuggets 题解报告

    题目描述 农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是"劣质的包装".& ...

  3. [USACO4.1]麦香牛块Beef McNuggets By cellur925

    题目描述 农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块.奶牛们正在想尽一切办法让这种可怕的设想泡汤.奶牛们进行斗争的策略之一是"劣质的包装".& ...

  4. 大麦网启动“麦香计划”,将投3亿元布局戏剧内容领域

    2月20日消息,大麦网旗下自营演出品牌Mailive发布"麦香计划",将投入3亿加大在戏剧内容领域的战略布局,从剧目运营.大数据营销等多个维度助力头部戏剧IP,全面扩增演出市场份额 ...

  5. P2737 [USACO4.1]麦香牛块Beef McNuggets 数学题 + 放缩思想

    https://www.luogu.org/problem/show?pid=2737#sub 先说一个结论:对于两个数p, q,且gcd(p, q) = 1(这个很重要,是条件来的).他们不能组合成 ...

  6. Codeforces Hello 2019 D. Makoto and a Blackboard[DP+数论+概率期望]

    题意:给出n和k,n每次会等概率的变成n的一个因子,问这样k次以后的期望大小 每个质因子贡献独立,变成一个因子就相当于变了质因子的次数 所以分解质因数以后对每个质因子做dp #include < ...

  7. CodeForces - 1497E2 Square-free division (hard version)(dp+数论)

    题目链接:点击查看 题目大意:给出一个长度为 nnn 的数列,现在最多可以修改 kkk 个数字为任意数值,现在问最少可以将数列划分成多少个连续的数列,使得每一个单独的段中,任意两个数的乘积都不能是完全 ...

  8. HDU - 6169 Senior PanⅡ(dp+数论)

    题目大意: 多组测试数据,每组给你三个数:l,r,k;让你输出区间 [ l , r ] 内所有最小不为 1 的因数是 k 的数的和.(l,r,k≤1011)(l,r,k \le 10^{11}) 分析 ...

  9. 【luogu2737】 [USACO4.1]麦香牛块Beef McNuggets [动态规划 完全背包][数学 扩展欧几里德]...

    证明应该是小凯的诱惑的升级版 应该可以用那个同余最短路来跑 1 #include<bits/stdc++.h> 2 using namespace std; 3 #define ll lo ...

最新文章

  1. View绘制流程的入口
  2. asp.net/c#字符格式化大总结
  3. VS2008中的“解决方案配置”和“解决方案平台”不见了(Release和Debug)的解决方法...
  4. 升级macOS新系统后,Xcode7.2 Xcode7.3.1 在新建项目界面,出现了文字错乱的情况
  5. C++安全方向openssl(二):2.2 C++代码实现base16编解码
  6. wait 和 sleep 区别
  7. 图解java_图解 Java 中的数据结构及原理!
  8. jquery的deferred使用详解
  9. php连接mysql配置环境变量_Win7 64位操作系统下配置PHP+MySql+Apache环境(转)
  10. 谷歌浏览器Chrome不能登录不能同步解决方法
  11. U8v10.1销售发货单打印模板取客户名称不正确的问题
  12. adapterview android,[Android]ListView+AdapterView
  13. QQ微信实时消息转发图片文件视频语音互联机器人自动发消息
  14. servlet003:监听器
  15. 使用canal实现MySQL 8 全量同步数据到 ElasticSearch 7.15.2中 linux
  16. python股票量化交易从入门到实践df_Python股票量化交易从入门到实践/金融科技系列...
  17. Pod环境变量和initContainer
  18. 华为android系统通知栏怎么关闭,华为通知栏怎么设置?三招帮你禁止华为通知栏消息...
  19. 抖音账号如何做好私域流量,私域流量是什么
  20. EF搜索数据自动将表名变复数问题

热门文章

  1. 中国移动光猫桥接模式
  2. linux 进程迁移,记一次成功的 linux 系统迁移
  3. android如何绑定事件,Android_安卓为按钮控件绑定事件的五种方式
  4. 分布式技术一周技术动态 2015.12.13
  5. shell从入门到精通(25)你知道什么是login shell和non login shell吗
  6. 十大管理之项目成本管理知识点
  7. mysql查看主机名_mysql怎么看主机名
  8. 解决一个assign问题,assign怎么用,assign有啥物理意义
  9. DesignPattern团队《设计模式在软件开发的应用》讨论会议记录
  10. Google 百度 图标收藏(二)