-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path21.cpp
More file actions
32 lines (31 loc) · 713 Bytes
/
21.cpp
File metadata and controls
32 lines (31 loc) · 713 Bytes
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
#include <cstdio>
#include <unordered_set>
#include "prime_factorization.h"
int main() {
constexpr size_t n = 10000;
std::uint64_t map[n];
map[0] = 0;
map[1] = 1;
std::uint64_t ans = 0;
for (std::uint64_t i = 2; i < n; ++i) {
auto fs = trial_division(i);
std::unordered_set<std::uint64_t> divisors;
divisors.insert(1);
for (auto &f : fs) {
auto tmp = divisors;
for (auto &d : tmp) {
divisors.insert(f * d);
}
}
std::uint64_t sum = 0;
for (auto &d : divisors) sum += d;
sum -= i;
// printf("%llu - ", i);
// for (auto &d : divisors) printf("%llu ", d);
// printf("\n");
map[i] = sum;
if (sum < i && map[sum] == i) ans += sum + i;
}
printf("%llu", ans);
return 0;
}