欧几里得+完全背包 蒸包子凑数
来源:互联网 发布:可视化编程软件 知乎 编辑:程序博客网 时间:2024/06/09 16:49
每当有顾客想买X个包子,卖包子的大叔就会迅速选出若干笼包子来,使得这若干笼中恰好一共有X个包子。比如一共有3种蒸笼,分别能放3、4和5个包子。当顾客想买11个包子时,大叔就会选2笼3个的再加1笼5个的(也可能选出1笼3个的再加2笼4个的)。
当然有时包子大叔无论如何也凑不出顾客想买的数量。比如一共有3种蒸笼,分别能放4、5和6个包子。而顾客想买7个包子时,大叔就凑不出来了。
小明想知道一共有多少种数目是包子大叔凑不出来的。
首先如果N种蒸笼的包子数是互质的,那么是有限的。如果不是互质的,那么直接输出INF即可。
如果是互质的,我们dp【0】=1.
之后用n个包子暴力遍历1-10000,看看哪些数能能凑出来即可
#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
int dp[10000];
bool judge(int x,int y)
{
int t;
while(y>0)
{
t=x%y;
x=y;
y=t;
}
if(x==1)
return true;
return false;
}
int main()
{
int a[200],n,i,j,res,mark;
while(scanf("%d",&n)!=EOF)
{
res=0;
mark=0;
memset(dp,0,sizeof(dp));
for(i=1;i<=n;i++)
{
scanf("%d",&a[i]);
}
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
if(judge(a[i],a[j]))
{
mark=1;
break;
}
}
if(mark==1)
break;
}
if(mark!=1)
{
printf("INF\n");
continue;
}
memset(dp,0,sizeof(dp));
dp[0]=1;
for(int i=1;i<=n;i++)
{
for(int j=0;j+a[i]<=10000;j++)
{
if(dp[j])
{
dp[j+a[i]]=true;
}
}
}
int cnt=0;
for(int i=1;i<=10000;i++)
{
if(!dp[i])
{
cnt++;
}
}
cout<<cnt<<endl;
}
return 0;
}
- 欧几里得+完全背包 蒸包子凑数
- 蒸包子凑数 完全背包 蓝桥杯
- 蓝桥杯-包子凑数(完全背包)
- 蓝桥杯 包子凑数(拓展欧几里得)
- 小白算法练习 简单背包专题003 完全背包 hdu lanqiao 包子凑数 dp
- 2017蓝桥杯C/C++A组省赛包子凑数(辗转相除法和完全背包)
- 包子凑数
- 包子凑数
- 包子凑数
- 蓝桥杯之包子凑数
- 第八届蓝桥杯包子凑数
- 第八届蓝桥杯第八题包子凑数
- 第八届蓝桥杯 java B组 包子凑数
- 蓝桥杯java第八届第八题--包子凑数
- 第八届蓝桥杯【省赛试题8】包子凑数
- 凑数
- 包子和馒头的恩怨完全版
- 包子
- 抽象类(abstract class)和接口(Interface)的区别
- CS本科毕业生能拿到45万年薪?
- c primer pius 练习二
- ORACLE最基本的设置
- UG二次开发-VS2010+C++怎样调试
- 欧几里得+完全背包 蒸包子凑数
- FreeMarker之表达式
- 自动化测试第一课:selenium + webdriver + python 是什么
- 个人学习记录文档2017年11月4号
- 文章标题
- 第三方登录——OAuth2.0协议
- No active profile set, falling back to default profiles: default
- 区块链和人工智能技术能否加速物联网经济的到来?
- jsp与el