QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#863429 | #9870. Items | yuanruiqi | WA | 2542ms | 21336kb | C++26 | 2.7kb | 2025-01-19 17:03:13 | 2025-01-19 17:03:43 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;
constexpr int maxn = (1 << 19) + 10;
constexpr int mod = 998244353;
i64 qp(i64 a, i64 b)
{
i64 c = 1;
for (; b; b>>=1, a=a*a%mod)
if (b & 1) c=c*a%mod;
return c;
}
int rev[maxn], w[maxn];
void ntt(i64 *a, int n, const int p = 3)
{
for (int i=1;i<n;++i) if (rev[i] > i) swap(a[i], a[rev[i]]);
for (int i=2,m=1;i<=n;i<<=1,m<<=1)
{
i64 W = qp(p, (mod - 1) / i);
for (int j=w[0]=1;j<m;++j) w[j] = w[j - 1] * W % mod;
for (int l=0,r=i-1;r<n;l+=i,r+=i)
for (int j=l;j<l+m;++j)
{
i64 x = a[j + m] % mod * w[j - l] % mod;
a[j + m] = a[j] - x + mod;
a[j] += x;
}
}
for (int j=0;j<n;++j) a[j] %= mod;
}
i64 a[maxn], b[maxn];
template<int zero, int mxn>
struct sth
{
#define vec array<i64, zero << 1>
// constexpr int zero = 100000 + 5; // [-len, len)
int n;
void init()
{
n = mxn;
for (int i=1;i<n;++i) rev[i] = rev[i >> 1] >> 1 | ((i & 1) ? (n >> 1) : 0);
}
vec mul(const vec &va, const vec &vb)
{
memset(a + zero * 2, 0, sizeof(i64) * (n - zero * 2));
memcpy(a, &va[0], sizeof(i64) * zero * 2);
memset(b + zero * 2, 0, sizeof(i64) * (n - zero * 2));
memcpy(b, &vb[0], sizeof(i64) * zero * 2);
ntt(a, n); ntt(b, n);
for (int i=0;i<n;++i) a[i] = a[i] * b[i] % mod;
ntt(a, n, (mod + 1) / 3);
i64 v = ::qp(n, mod - 2);
for (int i=0;i<n;++i) a[i] = a[i] * v % mod;
vec b;
memcpy(&b[0], a + zero, sizeof(i64) * (zero << 1));
return b;
// [-2len, 2len-1) -> [0, len + len), [-len, len)
}
vec qp(vec a, i64 b)
{
vec c = a; --b;
for (; b; b>>=1, a=mul(a,a))
if (b & 1) c=mul(c,a);
return c;
}
void solve(int n)
{
init();
int m;
cin >> m;
int x = m / n;
vector<int> w(n);
for (int i=0;i<n;++i) cin >> w[i], w[i] -= x;
m %= n;
vec a;
memset(&a, 0, sizeof(a));
for (int i=0;i<n;++i) ++a[w[i] + zero];
a = qp(a, n);
cout << (a[m + zero] ? "Yes\n" : "No\n");
}
};
template<int zero, int mxn>
void wat(int n)
{
sth<zero, mxn> s;
return s.solve(n);
}
template<int zero, int mxn>
void run(int n)
{
if constexpr (mxn < 20) return wat<zero, mxn>(n);
else
{
if (zero > n * 4) return run<(zero >> 1), (mxn >> 1)>(n);
else return wat<zero, mxn>(n);
}
}
void solve()
{
int n;
cin >> n;
run<100000 + 5, 1 << 19>(n);
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
int t;
cin >> t;
while (t--) solve();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 7732kb
input:
4 5 25 0 0 0 0 5 5 11 4 4 4 5 5 5 0 1 2 3 4 5 5 25 0 1 2 3 4
output:
Yes No No No
result:
ok 4 token(s): yes count is 1, no count is 3
Test #2:
score: 0
Accepted
time: 20ms
memory: 7784kb
input:
1314 1 0 0 1 0 1 1 1 0 1 1 1 2 0 0 0 2 0 0 1 2 0 0 2 2 0 1 0 2 0 1 1 2 0 1 2 2 0 2 0 2 0 2 1 2 0 2 2 2 1 0 0 2 1 0 1 2 1 0 2 2 1 1 0 2 1 1 1 2 1 1 2 2 1 2 0 2 1 2 1 2 1 2 2 2 2 0 0 2 2 0 1 2 2 0 2 2 2 1 0 2 2 1 1 2 2 1 2 2 2 2 0 2 2 2 1 2 2 2 2 2 3 0 0 2 3 0 1 2 3 0 2 2 3 1 0 2 3 1 1 2 3 1 2 2 3 2 0...
output:
Yes No No Yes Yes Yes Yes Yes No No Yes No No No Yes No Yes No No No No No No Yes Yes Yes Yes Yes Yes Yes No No No No No No Yes No Yes No No No Yes No No Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No No No Yes No No No Yes No No No Yes Yes Yes...
result:
ok 1314 token(s): yes count is 732, no count is 582
Test #3:
score: 0
Accepted
time: 172ms
memory: 7912kb
input:
10000 4 1 0 0 0 0 4 1 0 0 0 1 4 1 0 0 0 2 4 1 0 0 0 3 4 1 0 0 0 4 4 1 0 0 1 0 4 1 0 0 1 1 4 1 0 0 1 2 4 1 0 0 1 3 4 1 0 0 1 4 4 1 0 0 2 0 4 1 0 0 2 1 4 1 0 0 2 2 4 1 0 0 2 3 4 1 0 0 2 4 4 1 0 0 3 0 4 1 0 0 3 1 4 1 0 0 3 2 4 1 0 0 3 3 4 1 0 0 3 4 4 1 0 0 4 0 4 1 0 0 4 1 4 1 0 0 4 2 4 1 0 0 4 3 4 1 0 ...
output:
No Yes No No No Yes Yes Yes Yes Yes No Yes No No No No Yes No No No No Yes No No No Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No Yes No No No Yes Yes Yes Yes Yes No Yes No No No No Yes No No No No Yes No No No No Yes No No No Yes Yes Yes Yes ...
result:
ok 10000 token(s): yes count is 6168, no count is 3832
Test #4:
score: 0
Accepted
time: 28ms
memory: 7784kb
input:
1612 5 0 0 0 0 0 0 5 0 1 1 1 1 1 5 0 0 1 1 1 1 5 0 2 2 2 2 2 5 0 0 2 2 2 2 5 0 1 2 2 2 2 5 0 0 1 2 2 2 5 0 3 3 3 3 3 5 0 0 3 3 3 3 5 0 1 3 3 3 3 5 0 0 1 3 3 3 5 0 2 3 3 3 3 5 0 0 2 3 3 3 5 0 1 2 3 3 3 5 0 0 1 2 3 3 5 0 4 4 4 4 4 5 0 0 4 4 4 4 5 0 1 4 4 4 4 5 0 0 1 4 4 4 5 0 2 4 4 4 4 5 0 0 2 4 4 4 5...
output:
Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No No No Yes No No No Yes No No No Yes No No No Yes No No No Yes No No No Yes No No No...
result:
ok 1612 token(s): yes count is 864, no count is 748
Test #5:
score: 0
Accepted
time: 179ms
memory: 7912kb
input:
4662 6 0 0 0 0 0 0 0 6 0 1 1 1 1 1 1 6 0 0 1 1 1 1 1 6 0 2 2 2 2 2 2 6 0 0 2 2 2 2 2 6 0 1 2 2 2 2 2 6 0 0 1 2 2 2 2 6 0 3 3 3 3 3 3 6 0 0 3 3 3 3 3 6 0 1 3 3 3 3 3 6 0 0 1 3 3 3 3 6 0 2 3 3 3 3 3 6 0 0 2 3 3 3 3 6 0 1 2 3 3 3 3 6 0 0 1 2 3 3 3 6 0 4 4 4 4 4 4 6 0 0 4 4 4 4 4 6 0 1 4 4 4 4 4 6 0 0 1...
output:
Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No Yes No...
result:
ok 4662 token(s): yes count is 2730, no count is 1932
Test #6:
score: 0
Accepted
time: 1853ms
memory: 21332kb
input:
1 100000 9999999999 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 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 9...
output:
No
result:
ok NO
Test #7:
score: 0
Accepted
time: 456ms
memory: 7780kb
input:
10000 10 3 5 9 0 1 1 10 0 6 3 2 10 22 5 7 0 0 10 5 6 2 7 8 10 67 7 7 7 4 0 8 10 10 5 10 10 56 1 6 5 3 0 7 3 5 8 9 10 43 4 4 0 3 3 4 1 3 0 0 10 91 0 6 6 9 2 3 10 8 6 0 10 2 5 1 4 0 10 9 2 3 2 9 10 73 8 5 6 10 10 2 8 10 4 8 10 36 10 2 5 1 3 6 7 3 7 10 10 90 3 4 5 10 7 7 3 5 1 6 10 20 9 4 3 1 1 6 8 1 5...
output:
Yes Yes Yes Yes No Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No Yes No Yes Yes Yes Yes Yes Yes Yes Yes No Yes Yes Yes Yes Yes Yes Yes Yes No Yes Yes Yes No Yes Yes No No Yes Yes Yes Yes Yes Yes No No Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No Yes No No Yes Yes Yes Yes Yes Yes Yes Y...
result:
ok 10000 token(s): yes count is 8663, no count is 1337
Test #8:
score: 0
Accepted
time: 1350ms
memory: 7828kb
input:
1000 100 8921 54 82 23 19 31 95 88 97 10 26 61 50 49 10 4 29 90 60 20 73 45 95 44 96 47 20 24 39 15 35 78 24 78 60 100 36 63 53 70 42 61 78 38 64 0 38 80 99 9 77 68 84 71 75 63 57 38 32 1 74 75 53 0 18 74 80 79 49 31 90 61 81 28 16 72 81 58 76 33 68 76 15 96 65 59 27 0 75 47 85 8 27 55 36 28 49 33 6...
output:
Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No Yes Yes No Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Ye...
result:
ok 1000 token(s): yes count is 983, no count is 17
Test #9:
score: 0
Accepted
time: 2215ms
memory: 8304kb
input:
100 1000 822190 824 147 580 931 944 411 499 248 16 807 817 933 344 801 776 172 736 814 298 944 324 901 146 149 653 850 431 224 670 778 918 957 418 847 787 256 313 675 189 372 527 630 518 214 430 962 549 142 419 388 461 227 471 337 436 172 941 944 785 49 630 943 896 819 188 976 230 896 638 30 935 787...
output:
Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes ...
result:
ok 100 token(s): yes count is 100, no count is 0
Test #10:
score: 0
Accepted
time: 2542ms
memory: 14812kb
input:
10 10000 36452743 3219 2049 8923 2370 670 7258 1630 4309 5307 7756 4017 7973 4652 3806 8536 3319 6721 8996 9923 4793 944 7181 1293 6733 5461 9146 5187 3302 2405 8747 9377 2121 5977 3321 3013 1359 8648 5541 3697 4971 7303 7762 2025 695 7336 9420 6617 1496 1680 3299 8682 7302 5303 6835 8207 6786 7868 ...
output:
Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes
result:
ok 10 token(s): yes count is 10, no count is 0
Test #11:
score: -100
Wrong Answer
time: 1835ms
memory: 21336kb
input:
1 100000 7132922381 65268 98569 49569 42441 31688 75146 41758 82634 22278 88725 35755 66423 15583 10748 68319 15051 44705 17431 24789 61906 39753 44681 94285 31076 91405 10918 99048 31599 1684 65254 25364 73214 82162 76373 68973 12878 18037 43668 53394 65187 77671 17544 99819 82666 83485 20807 71773...
output:
No
result:
wrong answer expected YES, found NO [1st token]