Pagini recente » Cod sursa (job #1825590) | Cod sursa (job #2828483) | Cod sursa (job #2153719) | Cod sursa (job #669252) | Cod sursa (job #593783)
Cod sursa(job #593783)
#include<stdio.h>
#define MaxN 1001
int A[MaxN];
int c;
int d;
unsigned long long MAX;
int MAX1;
int MIN1;
inline int min(int a,int b)
{
return a<b? a:b;
}
inline int max(int a,int b)
{
return a>b? a:b;
}
int cmmdc(int a,int b)
{
if(!b) return a;
else return cmmdc(b,a%b);
}
int main()
{
FILE *f = fopen("mins.in","r");
FILE *g = fopen("mins.out","w");
fscanf(f,"%d %d",&c,&d);
MAX1 = max(c-1,d-1);
MIN1 = min(c-1,d-1);
for(int i=1;i<=MIN1;i++)
A[i] = i-1;
for(int i=2;i<=MIN1;i++)
{
for(int j=i+i;j<=MIN1;j+=i)
A[j] -= A[i];
MAX += 2*A[i];
}
for(int i=MIN1+1;i<=MAX1;i++)
for(int j=2;j<=MIN1;j++)
if(cmmdc(i,j) == 1)
MAX ++;
fprintf(g,"%d",MAX+1+(MAX1-MIN1));
fclose(g);
fclose(f);
return 0;
}