这,这,这就是原题啊。。。。。。。就在洛谷上摆着。。。。。。。
这告诉我们什么,美国题库,我来了!!!!!!!!!!!!!!!!@@@
题目描述
农夫布朗的奶牛们正在进行斗争,因为它们听说麦当劳正在考虑引进一种新产品:麦香牛块。奶牛们正在想尽一切办法让这种可怕的设想泡汤。奶牛们进行斗争的策略之一是“劣质的包装”。“看,”奶牛们说,“如果你只用一次能装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(如果所有购买方案都能得到满足或者顾客不能买到的块数没有上限)。
输入输出样例
输入
3 3 6 10
输出
17
这个题最大的枚举范围,由小凯的疑惑可知,最大为256256;
因为两个数不能表示的数是ab-(a+b)
**不知道为啥,虽然不互质i,但是他不会影响我们枚举的范围。23333333333333333 **
#include<bits/stdc++.h>
using namespace std;
const int maxn=90000;
int a[20],vis[maxn];
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)cin>>a[i],vis[a[i]]=1;
vis[0]=1;
for(int r=0;r<=maxn-10;r++)
for(int i=1;i<=n;i++)
if(vis[r])vis[r+a[i]]=1;
int ans=0;
for(int r=maxn-10;r>=0;r--)
if(!vis[r])
{
ans=r;break;
}
if(ans>80000)ans=0;
cout<<ans;
return 0;//拜拜程序
}