记录编号 584829 评测结果 AAAAAAAAAA
题目名称 最大公约数 最终得分 100
用户昵称 Gravatar┭┮﹏┭┮ 是否通过 通过
代码语言 C++ 运行时间 1.155 s
提交时间 2023-11-16 13:11:20 内存使用 8.93 MiB
显示代码纯文本
#include <bits/stdc++.h> 
using namespace std;
const int N = 1e5+10,M = 1e6+10;
int n,g,ans = INT_MAX;
int a[N],v[M];
int gcd(int x,int y){
    if(y == 0)return x;
    return gcd(y,x%y);
}
void fen(int x){
    for(int i = 1;i <= sqrt(x);i++)
        if(x % i == 0)v[i]++,v[x/i]++;
    int u = sqrt(x);
    if(u * u == x)v[u]--;
}
int main(){
    freopen("gcd.in","r",stdin);
    freopen("gcd.out","w",stdout);
    scanf("%d",&n);
    for(int i = 1;i <= n;i++){
        scanf("%d",&a[i]);
        if(i == 1)g = a[1];
        else g = gcd(g,a[i]);
        fen(a[i]);
    }
    for(int i = g+1;i <= 1e6;i++)
        ans = min(ans,n-v[i]);
    printf("%d\n",ans);
    
    return 0;
    
}