QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#800495 | #6446. Stretching Streamers | rlc202204 | AC ✓ | 39ms | 4524kb | C++14 | 1.1kb | 2024-12-06 11:55:13 | 2024-12-06 11:55:13 |
Judging History
answer
#include <iostream>
#include <cstdio>
#include <vector>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 305;
const int mod = 1e9 + 7;
int gcd(int x, int y) {
return x == 0 ? y : gcd(y % x, x);
}
void add(int &x, int y) {
x = (x + y) % mod;
}
int n;
int a[N] = {0};
bool vld[N][N] = {{false}};
int f[N][N] = {{0}}, g[N][N] = {{0}};
int main() {
cin >> n;
for (int i = 1; i <= n; i++)
cin >> a[i];
a[++n] = a[1];
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++)
vld[i][j] = (gcd(a[i], a[j]) > 1);
for (int i = 1; i <= n; i++) {
if (i < n)
g[i][i + 1] = vld[i][i + 1], f[i][i + 1] = 1;
g[i][i] = 1;
}
for (int len = 3; len <= n; len++)
for (int l = 1; l + len - 1 <= n; l++) {
int r = l + len - 1;
for (int i = l + 1; i < r; i++)
if (vld[l][i])
add(f[l][r], 1ll * f[l][i] * f[i][r] % mod);
add(f[l][r], g[l + 1][r]);
for (int i = l; i < r; i++)
if (vld[i][r])
add(g[l][r], 1ll * g[l][i] * f[i][r] % mod);
}
cout << g[2][n] << endl;
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3680kb
input:
4 30 3 2 45
output:
1
result:
ok 1 number(s): "1"
Test #2:
score: 0
Accepted
time: 0ms
memory: 3612kb
input:
4 3 30 2 45
output:
3
result:
ok 1 number(s): "3"
Test #3:
score: 0
Accepted
time: 12ms
memory: 4524kb
input:
300 1033 239 1867 337 269 1777 761 53 277 439 97 1741 1499 191 1567 1087 1117 307 1367 2 593 977 71 947 1051 797 397 1949 19 101 1733 701 379 641 683 1627 1301 1049 1493 127 1873 211 547 173 419 877 1019 131 661 769 263 929 839 827 1399 1213 281 431 1237 727 373 257 1361 487 1093 13 521 577 311 461 ...
output:
0
result:
ok 1 number(s): "0"
Test #4:
score: 0
Accepted
time: 21ms
memory: 4468kb
input:
300 2157 237 2855 205 2105 6865 1415 33 6085 5469 415 895 177 5001 3261 7115 3805 591 993 3305 417 1115 39 5277 939 4555 5105 1347 4701 4737 501 9935 2019 141 2845 5815 1795 951 129 1315 1345 3845 2935 4135 3695 4449 681 6115 4629 2271 4497 3545 3715 1527 785 1101 1851 4791 2361 3579 4317 5045 4115 ...
output:
0
result:
ok 1 number(s): "0"
Test #5:
score: 0
Accepted
time: 39ms
memory: 4476kb
input:
300 4907 7903 4529 11893 6629 91 1883 4627 2611 1337 1477 4249 2359 11599 13097 11683 4109 4739 9247 7133 1799 11879 2681 3017 8939 10451 3983 10381 1267 3101 3829 7763 9149 791 259 11081 3647 13069 8267 469 2191 7231 8309 4837 1561 2653 10577 3493 11963 721 511 2219 4319 889 6839 8981 4207 1351 529...
output:
0
result:
ok 1 number(s): "0"
Test #6:
score: 0
Accepted
time: 0ms
memory: 3724kb
input:
4 10 5 3 6
output:
1
result:
ok 1 number(s): "1"
Test #7:
score: 0
Accepted
time: 1ms
memory: 3792kb
input:
50 2 6 2 6 3 2 3 2 2 6 3 3 6 3 2 3 3 6 2 3 3 6 2 2 2 6 3 2 3 6 6 6 2 6 2 6 3 2 3 2 6 3 2 6 2 2 3 3 3 3
output:
899570939
result:
ok 1 number(s): "899570939"
Test #8:
score: 0
Accepted
time: 24ms
memory: 4396kb
input:
300 3155 6395 1149 8885 5165 2195 3865 4685 6295 4265 1315 5259 1203 3 35 939 235 5345 3651 6835 4765 1985 7835 4855 4659 339 1779 3095 7445 3903 921 2571 681 2335 1285 5305 2215 2217 5703 7195 4461 5245 6635 2855 4195 2103 8285 1077 7915 3295 1945 5435 3909 5541 9355 2271 4737 4287 1205 1347 237 65...
output:
0
result:
ok 1 number(s): "0"
Test #9:
score: 0
Accepted
time: 0ms
memory: 3760kb
input:
10 15 3 5 30 15 3 30 5 2 30
output:
19963
result:
ok 1 number(s): "19963"
Test #10:
score: 0
Accepted
time: 0ms
memory: 3736kb
input:
10 6 5 3 15 2 5 30 15 5 5
output:
265
result:
ok 1 number(s): "265"
Test #11:
score: 0
Accepted
time: 27ms
memory: 4464kb
input:
300 201191306 918051452 780961841 645973722 286503057 882088849 513073051 310381490 799200094 402805419 532979835 489021379 852948197 220768063 635297990 751356303 890115969 3130656 220308158 567483486 583338957 951560857 763149373 971135261 368520705 760496995 689532954 608871704 327670623 44169399...
output:
0
result:
ok 1 number(s): "0"
Test #12:
score: 0
Accepted
time: 39ms
memory: 4468kb
input:
300 2071 6631 31711 19931 31597 20843 12559 5567 3743 15713 5377 18677 35663 2413 23731 28709 8759 18563 6289 31483 9899 8417 23921 2831 1919 28253 13661 34219 9329 8189 14383 15409 7543 9481 10849 25973 6593 13129 11381 27569 20653 20729 33763 29089 209 29849 7277 30001 22553 2641 30761 15637 4997 ...
output:
176726131
result:
ok 1 number(s): "176726131"
Test #13:
score: 0
Accepted
time: 24ms
memory: 4524kb
input:
300 999999712 999999930 999999994 999999890 999999884 999999971 999999767 999999976 999999858 999999843 999999960 999999931 999999999 999999905 999999817 999999856 999999849 999999962 999999969 999999986 999999984 999999956 999999902 999999728 999999837 999999865 999999744 999999913 999999857 999999...
output:
0
result:
ok 1 number(s): "0"
Test #14:
score: 0
Accepted
time: 24ms
memory: 4404kb
input:
300 999999917 999999789 999999727 999999984 999999702 999999926 999999709 999999724 999999978 999999699 999999830 999999856 999999791 999999712 999999952 999999823 999999888 999999732 999999849 999999772 999999738 999999969 999999991 999999867 999999988 999999780 999999890 999999900 999999912 999999...
output:
0
result:
ok 1 number(s): "0"
Test #15:
score: 0
Accepted
time: 25ms
memory: 4344kb
input:
300 505 3305 3849 3543 4881 5105 453 4295 1527 3777 321 4857 7915 395 5739 1985 4055 2045 1923 3693 2285 995 2361 417 1149 2435 2127 1713 5169 5935 545 6905 4435 9 6635 1821 2859 2615 145 1685 2495 7195 1405 1839 2005 2515 7495 5455 3005 4269 2391 1865 1437 6445 4115 123 3039 2757 65 1745 8935 4377 ...
output:
550226165
result:
ok 1 number(s): "550226165"
Test #16:
score: 0
Accepted
time: 14ms
memory: 4516kb
input:
300 6 15 35 77 143 221 323 437 667 899 1147 1517 1763 2021 2491 3127 3599 4087 4757 5183 5767 6557 7387 8633 9797 10403 11021 11663 12317 14351 16637 17947 19043 20711 22499 23707 25591 27221 28891 30967 32399 34571 36863 38021 39203 41989 47053 50621 51983 53357 55687 57599 60491 64507 67591 70747 ...
output:
1
result:
ok 1 number(s): "1"