Pagini recente » Cod sursa (job #2702132) | Cod sursa (job #3032681) | Cod sursa (job #1089921) | Cod sursa (job #3124062) | Cod sursa (job #3299378)
#include <fstream>
#include <vector>
using namespace std;
void ciur(int n, vector <int> &pdp, vector <int> &nrdp)
{
for (int d = 2; d <= n; d++)
{
if (nrdp[d] == 0)
{
for (int m = d; m <= n; m += d)
{
pdp[m] *= d;
nrdp[m]++;
}
}
}
}
int main()
{
ifstream in("mins.in");
ofstream out("mins.out");
int c, d;
in >> c >> d;
c--;
d--;
int n = max(c, d);
vector <int> pdp(n + 1, 1);
vector <int> nrdp(n + 1, 0);
ciur(n, pdp, nrdp);
long long suma = 0;
for (int i = 1; i <= n; i++)
{
if (pdp[i] == i)
{
long long termen = (long long)c / i;
termen *= d / i;
if (nrdp[i] % 2 == 0)
{
suma += termen;
}
else
{
suma -= termen;
}
}
}
out << suma << "\n";
in.close();
out.close();
return 0;
}