QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#302036 | #7954. Special Numbers | mariowong# | WA | 1ms | 3576kb | C++17 | 4.0kb | 2024-01-10 15:37:52 | 2024-01-10 15:37:52 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int MOD = 1e9 + 7;
int primes[] = {2, 3, 5, 7};
// no of ptimes for 1 to 9, starts from 1
int dip[9][4] = {{0, 0, 0, 0},
{1, 0, 0, 0},
{0, 1, 0, 0},
{2, 0, 0, 0},
{0, 0, 1, 0},
{1, 1, 0, 0},
{0, 0, 0, 1},
{3, 0, 0, 0},
{0, 2, 0, 0}};
int cnt[4], digit[25];
ll f[2][2][57][41][21][21];
ll calc(ll n) {
ll kt = n;
int m = 0;
stack <int> tt;
while (kt) {
tt.push(kt % 10);
kt /= 10, m++;
}
for (int i = 0; i < m; i++) {
digit[i] = tt.top();
tt.pop();
}
for (int w = 0; w <= cnt[0]; w++) {
for (int x = 0; x <= cnt[1]; x++) {
for (int y = 0; y <= cnt[2]; y++) {
for (int z = 0; z <= cnt[3]; z++) {
f[0][0][w][x][y][z] = f[0][1][w][x][y][z] = 0;
}
}
}
}
f[0][1][0][0][0][0] = 1;
for (int i = 0; i < m; i++) {
int cur = i & 1, nxt = cur ^ 1;
for (int w = 0; w <= cnt[0]; w++) {
for (int x = 0; x <= cnt[1]; x++) {
for (int y = 0; y <= cnt[2]; y++) {
for (int z = 0; z <= cnt[3]; z++) {
f[nxt][0][w][x][y][z] = f[nxt][1][w][x][y][z] = 0;
}
}
}
}
for (int w = 0; w <= cnt[0]; w++) {
for (int x = 0; x <= cnt[1]; x++) {
for (int y = 0; y <= cnt[2]; y++) {
for (int z = 0; z <= cnt[3]; z++) {
//transition for not cur max
for (int tt = 0; tt < 9; tt++) {
int tw = min(w + dip[tt][0], cnt[0]);
int tx = min(x + dip[tt][1], cnt[1]);
int ty = min(y + dip[tt][2], cnt[2]);
int tz = min(z + dip[tt][3], cnt[3]);
f[nxt][0][tw][tx][ty][tz] = (f[nxt][0][tw][tx][ty][tz] + f[cur][0][w][x][y][z]) % MOD;
}
if (i) f[nxt][0][cnt[0]][cnt[1]][cnt[2]][cnt[3]] = (f[nxt][0][cnt[0]][cnt[1]][cnt[2]][cnt[3]] + f[cur][0][w][x][y][z]) % MOD;
//transition for current is max
for (int tt = 0; tt < digit[i] - 1; tt++) {
int tw = min(w + dip[tt][0], cnt[0]);
int tx = min(x + dip[tt][1], cnt[1]);
int ty = min(y + dip[tt][2], cnt[2]);
int tz = min(z + dip[tt][3], cnt[3]);
f[nxt][0][tw][tx][ty][tz] = (f[nxt][0][tw][tx][ty][tz] + f[cur][1][w][x][y][z]) % MOD;
}
if (digit[i] > 0) {
if (i) f[nxt][0][cnt[0]][cnt[1]][cnt[2]][cnt[3]] = (f[nxt][0][cnt[0]][cnt[1]][cnt[2]][cnt[3]] + f[cur][1][w][x][y][z]) % MOD;
int tw = min(w + dip[digit[i] - 1][0], cnt[0]);
int tx = min(x + dip[digit[i] - 1][1], cnt[1]);
int ty = min(y + dip[digit[i] - 1][2], cnt[2]);
int tz = min(z + dip[digit[i] - 1][3], cnt[3]);
f[nxt][1][tw][tx][ty][tz] = (f[nxt][1][tw][tx][ty][tz] + f[cur][1][w][x][y][z]) % MOD;
}
else
f[nxt][1][cnt[0]][cnt[1]][cnt[2]][cnt[3]] = (f[nxt][1][cnt[0]][cnt[1]][cnt[2]][cnt[3]] + f[cur][1][w][x][y][z]) % MOD;
}
}
}
}
// include number that start at this pos
if (i) {
for (int tt = 0; tt < 9; tt++) {
int tw = min(dip[tt][0], cnt[0]);
int tx = min(dip[tt][1], cnt[1]);
int ty = min(dip[tt][2], cnt[2]);
int tz = min(dip[tt][3], cnt[3]);
f[nxt][0][tw][tx][ty][tz] = (f[nxt][0][tw][tx][ty][tz] + 1) % MOD;
}
}
// cout << digit[i] << endl;
// for (int w = 0; w <= cnt[0]; w++) {
// for (int x = 0; x <= cnt[1]; x++) {
// for (int y = 0; y <= cnt[2]; y++) {
// for (int z = 0; z <= cnt[3]; z++) {
// cout << i << ' ' << w << ' ' << x << ' ' << y << ' ' << z << ' ' << f[nxt][0][w][x][y][z] << ' ' << f[nxt][1][w][x][y][z] << endl;
// }
// }
// }
// }
}
return (f[m & 1][0][cnt[0]][cnt[1]][cnt[2]][cnt[3]] + f[m & 1][1][cnt[0]][cnt[1]][cnt[2]][cnt[3]]) % MOD;
}
int main(){
ios::sync_with_stdio(false);
cin.tie(0); cout.tie(0);
ll k, l, r; cin >> k >> l >> r;
for (int i = 0; i < 4; i++) {
while (k % primes[i] == 0) {
k /= primes[i];
cnt[i]++;
}
}
if (k != 1) {
cout << 0 << endl;
return 0;
}
cout << (calc(r) - calc(l - 1) + MOD) % MOD << endl;
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 1ms
memory: 3404kb
input:
5 1 20
output:
4
result:
ok single line: '4'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3576kb
input:
5 50 100
output:
19
result:
ok single line: '19'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3520kb
input:
15 11 19
output:
0
result:
ok single line: '0'
Test #4:
score: 0
Accepted
time: 1ms
memory: 3460kb
input:
1 100 100000
output:
99901
result:
ok single line: '99901'
Test #5:
score: -100
Wrong Answer
time: 1ms
memory: 3564kb
input:
1 1 1
output:
0
result:
wrong answer 1st lines differ - expected: '1', found: '0'