Pagini recente » Borderou de evaluare (job #1387963) | Borderou de evaluare (job #1686223) | Borderou de evaluare (job #582775) | Borderou de evaluare (job #1392118) | Cod sursa (job #2501211)
#include <bits/stdc++.h>
using namespace std;
long long ciur[1000005],f[1000005];
int main()
{
ifstream cin ("pairs.in");
ofstream cout ("pairs.out");
long long n,i,j,maxx=-1;
cin>>n;
for(i=1;i<=n;i++)
{
cin>>j;
if(j>maxx)
maxx=j;
f[j]++;
}
long long sum=0;
for(i=2;i<=maxx/2;i++)
{
long long cnt=0;
if(ciur[i]==0)
{
for(j=i;j<=maxx;j+=i)
{
if(f[j]==1)
cnt++;
ciur[j]=1;
}
}
sum+=(cnt*(cnt-1)/2);
}
long long sumtot=n*(n-1)/2;
cout<<sumtot-sum;
return 0;
}