ACdream OJ 1153 (k-GCD)
来源:互联网 发布:百香坊沉香淘宝 编辑:程序博客网 时间:2024/05/16 08:36
题目链接:
http://115.28.76.232/problem?pid=1153
题意:
从给定的n个数中取出k个数,使得他们的最大公约数最大,求这个最大的公约数
分析:
暴力分解不可取,我们可以得到最大公约数肯定在[1,mmax]之间(mmax为其中最大的元素),由于mmax不大,
因此我们可以从大到小枚举公约数,然后统计它的倍数的个数是不是大于等于k,如果是的话那么这个数必然是最大的。
代码如下:
#include <iostream>#include <cstdio>#include <cstring>using namespace std;const int maxn = 10010;int a[maxn];int main(){ int n,k,t,x; scanf("%d",&t); while(t--){ scanf("%d%d",&n,&k); memset(a,0,sizeof(a)); int mmax = 0; for(int i=0;i<n;i++){ scanf("%d",&x); a[x]++; if( x > mmax) mmax = x; } int ans; bool f=0; for(int i=mmax;i>=1;i--){ int cnt=0; for(int j=i;j<=mmax;j+=i){ cnt += a[j]; if(cnt>=k){ ans = i; f=1; break; } } if(f) break; } printf("%d\n",ans); } return 0;}
0 0
- ACdream OJ 1153 (k-GCD)
- ACdream OJ 1099 瑶瑶的第K大
- 学院OJ 1832: GCD(k, n)>=m
- ACdream群OJ--1035
- ACdream OJ 完美数
- ACdream OJ 1099 瑶瑶的第K大 --分治+IO优化 - whatbeg
- 【ACdream OJ 1099 - 瑶瑶的第K大 (输入优化+手写O(n)快排)】
- AcDream OJ 1127 Base Station
- ACdream OJ 1154 Lowbit Sum
- ACdream OJ 1063 平衡树
- OJ k
- UVa OJ 11417-GCD
- 新视野OJ 2818: Gcd
- 南邮 OJ 1126 GCD
- ACdream群OJ 1122 数位DP
- ACdream群OJ 1126 Rankings 填坑法DP
- ACdream群OJ 1131 Apple 博弈
- ACdream群OJ 1157 cdq分治
- UIImageView处理, 图片处理
- CSA 第五届讨论会 畅想
- 数据库的ACID(酸性)总结
- PLSQL--集合
- memcached client -- memcached client for java使用
- ACdream OJ 1153 (k-GCD)
- weblogic 理解MBean
- C++中构造函数的执行顺序
- cgroups
- kkjcre1p: unable to spawn jobq slave process的排查思路
- C++类和对象的大小
- 最值得学习阅读的10个C语言开源项目代码
- 设计模式之——工厂模式(A)
- poj2528 线段树 离散化