-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathcount-the-number-of-powerful-integers.cpp
71 lines (66 loc) · 2.01 KB
/
count-the-number-of-powerful-integers.cpp
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// Time: O(logf)
// Space: O(1)
// math, combinatorics
class Solution {
public:
long long numberOfPowerfulInt(long long start, long long finish, int limit, string s) {
const auto& count = [&](int64_t x) {
const auto& length = [](int64_t x) {
int result = 0;
for (; x; x /= 10) {
++result;
}
return result;
};
int64_t result = 0;
const int n = length(x);
const int l = n - size(s);
int64_t base = powl(10, n);
int i = 0;
for (int64_t cnt = powl(limit + 1, l); i < l; ++i) {
base /= 10;
const int curr = x / base % 10;
cnt /= limit + 1;
result += (min(curr - 1, limit) - 0 + 1) * cnt;
if (curr > limit) {
break;
}
}
if (i == l) {
if (x % base >= stoll(s)) {
++result;
}
}
return result;
};
return count(finish) - count(start - 1);
}
};
// Time: O(logf)
// Space: O(logf)
// math, combinatorics
class Solution2 {
public:
long long numberOfPowerfulInt(long long start, long long finish, int limit, string s) {
const auto& count = [&](int64_t x) {
int64_t result = 0;
const auto& str_x = to_string(x);
const int l = size(str_x) - size(s);
int i = 0;
for (int64_t cnt = powl(limit + 1, l); i < l; ++i) {
cnt /= limit + 1;
result += (min((str_x[i] - '0') - 1, limit) - 0 + 1) * cnt;
if (str_x[i] - '0' > limit) {
break;
}
}
if (i == l) {
if (stoll(str_x.substr(l)) >= stoll(s)) {
++result;
}
}
return result;
};
return count(finish) - count(start - 1);
}
};