[USACO4.1]麦香牛块Beef McNuggets By cellur925
2024-08-29 20:46:48
题目描述
农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块。奶牛们正在想尽一切办法让这种可怕的设想泡汤。奶牛们进行斗争的策略之一是“劣质的包装”。“看,”奶牛们说,“如果你只用一次能装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 ;
}
最新文章
- 客服小妹是如何泡到手的——C#定时提醒&#183;语音录制&#183;语音播放&#183;文件转录Demo源码——倾情奉献!
- 窥探Swift之使用Web浏览器编译Swift代码以及Swift中的泛型
- Oracle connect by 树查询之二
- iOS字符串为空的判断
- Java NIO原理和使用
- Yii框架第一步-- 安装
- xiaoxia的vim配置
- .NET获取英文月份缩写名(可获取其他国家)
- Dubbo源码学习--服务是如何发布的
- ES6块级作用域
- 设置ActiveMQ的访问密码
- GridView用法
- Oracle 11g数据库的创建
- Java工具类DateFormatUtils详解
- Mininet入门与实战 3.9参课记录
- java 组合接口时的名字冲突
- 关于Unity中LOD和渲染队列----渲染通道通用指令(一)
- 【代码审计】iZhanCMS_v2.1 后台存在多个SQL注入漏洞分析
- C#实现局部峰值查找,功能对应Matlab中的findpeaks.m
- HDU 3001 Travelling(状态压缩DP+三进制)
热门文章
- [bzoj3998][TJOI2015]弦论_后缀自动机
- Atom安装代码格式化插件atom-beautify
- Spring中基于AOP的@AspectJ
- sys.argv的妙用:python命令行参数列表的修改、增加、删除
- ffm算法
- Windows7系统下优化固态硬盘
- Office EXCEL 如何保留一位小数,并且单击这个单元格的时候没有一大串小数
- 编程之美 之 让CPU占用率听你指挥
- 【问题记录】LoadRunner 接口压测-json格式报文
- 微博试水卖车社交电商怎样令4S“颤抖”?