题目描述

农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块。奶牛们正在想尽一切办法让这种可怕的设想泡汤。奶牛们进行斗争的策略之一是“劣质的包装”。“看,”奶牛们说,“如果你只用一次能装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。

在路上想了很久这个题......

【注意题目迁移】有没有感觉这题和小凯的诱惑疑惑十分相像?正解就是在那题的基础上进行枚举。

定理: 对于正整数 p , q 满足 gcd(p,q)=1 , 我们有 px + qy = n 无非负整数解的最大正整数 n 为 pq - p - q。

证明什么的不重要

有了这个结论,我们就可以愉快的进行完全背包(每个物品有无限个可用,在这里完全背包更像是一个bool作用)。

code

 #include<cstdio>
#include<algorithm> using namespace std; int n;
int f[];
int a[]; int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
if(a[i]==)
{
printf("");
return ;
}
}
sort(a+,a++n);
int cellur=*;
f[]=;
for(int i=;i<=n;i++)
for(int j=a[i];j<=cellur;j++)
if(f[j-a[i]]) f[j]=;
for(int i=cellur;i>=;i--)
if(!f[i])
{
if(i>cellur-*) i=;
printf("%d",i);
return ;
}
return ;
}

最新文章

  1. 客服小妹是如何泡到手的——C#定时提醒&#183;语音录制&#183;语音播放&#183;文件转录Demo源码——倾情奉献!
  2. 窥探Swift之使用Web浏览器编译Swift代码以及Swift中的泛型
  3. Oracle connect by 树查询之二
  4. iOS字符串为空的判断
  5. Java NIO原理和使用
  6. Yii框架第一步-- 安装
  7. xiaoxia的vim配置
  8. .NET获取英文月份缩写名(可获取其他国家)
  9. Dubbo源码学习--服务是如何发布的
  10. ES6块级作用域
  11. 设置ActiveMQ的访问密码
  12. GridView用法
  13. Oracle 11g数据库的创建
  14. Java工具类DateFormatUtils详解
  15. Mininet入门与实战 3.9参课记录
  16. java 组合接口时的名字冲突
  17. 关于Unity中LOD和渲染队列----渲染通道通用指令(一)
  18. 【代码审计】iZhanCMS_v2.1 后台存在多个SQL注入漏洞分析
  19. C#实现局部峰值查找,功能对应Matlab中的findpeaks.m
  20. HDU 3001 Travelling(状态压缩DP+三进制)

热门文章

  1. [bzoj3998][TJOI2015]弦论_后缀自动机
  2. Atom安装代码格式化插件atom-beautify
  3. Spring中基于AOP的@AspectJ
  4. sys.argv的妙用:python命令行参数列表的修改、增加、删除
  5. ffm算法
  6. Windows7系统下优化固态硬盘
  7. Office EXCEL 如何保留一位小数,并且单击这个单元格的时候没有一大串小数
  8. 编程之美 之 让CPU占用率听你指挥
  9. 【问题记录】LoadRunner 接口压测-json格式报文
  10. 微博试水卖车社交电商怎样令4S“颤抖”?