Pagini recente » Cod sursa (job #587352) | Cod sursa (job #1602573) | Cod sursa (job #2612206) | Cod sursa (job #2735447) | Cod sursa (job #2447075)
#include <iostream>
#include <fstream>
#include <queue>
#include <string>
#include <algorithm>
using namespace std;
long long numar=0;
int v[1000005],n,a[100005],maxim=0;
bool carac[1000005],carac2[1000005];
ifstream f("pairs.in");
ofstream g("pairs.out");
int main()
{
f>>n;
for(int i=1;i<=n;i++)
{
f>>a[i];
if(a[i]>maxim) maxim=a[i];
carac2[a[i]]=1;
}
for(int i=2;i<=maxim;i++)
if(carac[i]==0)
{
for(int j=i;j<=maxim;j+=i)
carac[j]=1;
int r=0;
for(int j=maxim-maxim%i;j>=2;j-=i)
if(carac2[j]==1)
{
v[j]+=r;
r++;
}
}
sort(a+1,a+n+1);
for(int i=1;i<=n;i++)
{
n--;
numar+=(n-v[a[i]]);
}
g<<numar;
}