#include <iostream>
#include <cmath>
using namespace std;
long r = 0;
void factor(long x) {
if (x <= 4)
return;
if (x % 2 == 0)
r += 1;
long sx = sqrt(x);
for (long y = 3; y <= sx; y++)
if (x % y == 0)
r += y * y == x ? 1 : 2;
}
long answer(long n) {
r = 0;
long sn = sqrt(n);
for (long p = 1; p <= sn; p++) {
if (n % p == 0) {
factor(p - 1);
if (p * p != n)
factor(n / p - 1);
}
}
return r;
}
int main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
long n;
cin >> n;
cout << answer(n) << "\n";
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | #include <iostream> #include <cmath> using namespace std; long r = 0; void factor(long x) { if (x <= 4) return; if (x % 2 == 0) r += 1; long sx = sqrt(x); for (long y = 3; y <= sx; y++) if (x % y == 0) r += y * y == x ? 1 : 2; } long answer(long n) { r = 0; long sn = sqrt(n); for (long p = 1; p <= sn; p++) { if (n % p == 0) { factor(p - 1); if (p * p != n) factor(n / p - 1); } } return r; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); long n; cin >> n; cout << answer(n) << "\n"; } |
English