首页 > 代码库 > 第八届蓝桥杯省赛C/C++ A组第8题 包子凑数
第八届蓝桥杯省赛C/C++ A组第8题 包子凑数
参考了http://blog.csdn.net/y1196645376/article/details/69718192
思路:
数论+完全背包。
实现:
1 #include <iostream> 2 #include <cstdio> 3 using namespace std; 4 5 const int MAXN = 100005; 6 7 int a[105], ok[MAXN], n; 8 9 int gcd(int x, int y) 10 { 11 return !y ? x : gcd(y, x % y); 12 } 13 14 int main() 15 { 16 cin >> n; 17 for (int i = 0; i < n; i++) 18 { 19 cin >> a[i]; 20 } 21 int g = a[0]; 22 for (int i = 1; i < n; i++) 23 { 24 g = gcd(g, a[i]); 25 } 26 if (g != 1) 27 puts("INF"); 28 else 29 { 30 ok[0] = true; 31 for (int i = 0; i < n; i++) 32 { 33 for (int j = 0; j + a[i] < MAXN; j++) 34 { 35 if (ok[j]) 36 { 37 ok[j + a[i]] = true; 38 } 39 } 40 } 41 int cnt = 0; 42 for (int i = 0; i < MAXN; i++) 43 { 44 if (!ok[i]) 45 cnt++; 46 } 47 printf("%d\n", cnt); 48 } 49 return 0; 50 }
第八届蓝桥杯省赛C/C++ A组第8题 包子凑数
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。