Cod sursa(job #1791692)
Utilizator | Data | 29 octombrie 2016 17:15:33 | |
---|---|---|---|
Problema | Mins | Scor | 50 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.66 kb |
#include <iostream>
#include<fstream>
using namespace std;
char nrdiv[1000005];
int i,j,t,n,m,sgn;
long long pairs,sum;
int main()
{
ifstream f("mins.in");
ofstream g("mins.out");
f>>n>>m;n--;m--;
for(i=2;i<=n;i++)
{
if(nrdiv[i]!=-1)
for(j=i;j<=n;j+=i)
{
if((j/i)%i==0) nrdiv[j]=-1;
if(nrdiv[i]<=1&&nrdiv[j]!=-1) nrdiv[j]++;
}
if(nrdiv[i]!=-1)
{
if(nrdiv[i]%2==0) sgn=-1;
else sgn=1;
sum+=(1LL)*(n/i)*(m/i)*sgn;
cout<<(n/i)*(m/i)*sgn<<'\n';
}
}
pairs=m*(n)-sum;
g<<pairs;
return 0;
}