QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#696503 | #7679. Master of Both IV | chikel | WA | 21ms | 5648kb | C++20 | 1.3kb | 2024-10-31 22:57:14 | 2024-10-31 22:57:14 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using i128 = __int128_t;
#define int long long
#define endl '\n'
#define ar array<int,2>
#define fi first
#define se second
random_device rd;
mt19937 mt(rd());
const int md = 998244353;
const int N = 5e5+10;
const int inf= 1e18;
const double eps=1e-10;
int p[N],cnt,a[N];
int ksm(int base, int power, int p) {
int result = 1;
while (power > 0) {
if (power & 1)result = result * base % p;
base = base * base % p ;
power >>= 1;
}
return result % p;
}
void insert(int x) {
for(int i=60; i>=0; i--) {
if((x>>i)&1) {
if(!p[i]) {
p[i]=x;
cnt++;
return ;
} else
x^=p[i];
}
}
}
void solve() {
int ans=0;
cnt=0;
int n;
cin >> n;
for(int i=60; i>=0; i--)
p[i]=0;
for(int i=1; i<=n; i++)
a[i]=0;
for(int i=1; i<=n; i++) {
int k;
cin >> k;
insert(k);
a[k]++;
}
for(int i=1; i<=n; i++) {
int o=1;
if(a[i]) {
for(int j=1; j*j<=i; j++) {
if(j!=i&&i%j==0) {
o=(o*ksm(2,a[j]-1,md))%md;
if(j*j!=i&&i/j!=i)
o=(o*ksm(2,a[i/j]-1,md))%md;
}
}
ans=(ans+ksm(2,a[i]-1,md)*o%md)%md;
}
}
ans=(ans+ksm(2,n-cnt,md))%md;
cout << ans-1 << endl;
}
signed main() {
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
solve();
}
}
详细
Test #1:
score: 100
Accepted
time: 1ms
memory: 5608kb
input:
2 3 1 2 3 5 3 3 5 1 1
output:
4 11
result:
ok 2 number(s): "4 11"
Test #2:
score: 0
Accepted
time: 20ms
memory: 5616kb
input:
40000 5 4 2 5 5 5 5 5 5 5 5 4 5 1 4 4 4 2 5 2 5 2 4 1 5 3 2 4 5 3 5 1 5 5 3 4 5 5 5 5 4 3 5 4 3 3 5 1 5 4 5 5 2 1 5 2 5 4 2 5 5 3 4 3 4 3 5 5 3 5 1 3 5 5 1 2 4 4 5 4 2 5 1 5 5 5 4 2 5 4 5 5 2 5 2 4 5 1 4 5 4 5 5 4 2 3 2 3 5 1 4 1 3 5 5 1 1 2 1 5 5 5 2 5 1 3 5 3 1 2 5 3 5 5 5 1 1 5 5 2 2 2 1 3 5 3 1 ...
output:
9 16 9 9 8 8 9 8 8 9 13 8 8 8 8 9 12 9 11 15 8 8 17 13 8 11 8 8 8 13 15 9 9 8 8 8 11 9 11 13 15 9 17 9 8 8 8 13 11 8 9 11 8 8 11 15 9 8 9 8 8 15 11 8 17 9 15 8 8 8 12 9 9 11 8 13 9 8 15 8 8 9 8 8 8 15 8 11 13 8 9 11 8 19 11 13 19 17 13 15 8 8 8 9 8 9 13 15 17 9 9 17 9 11 9 9 11 9 9 11 8 9 9 13 15 11...
result:
ok 40000 numbers
Test #3:
score: -100
Wrong Answer
time: 21ms
memory: 5648kb
input:
20000 10 1 3 6 8 3 1 10 7 2 3 10 8 2 8 9 10 5 8 4 8 3 10 2 2 10 1 6 4 4 3 4 7 10 6 5 10 7 8 7 3 1 6 6 10 3 2 3 7 8 4 9 8 8 7 10 9 9 6 4 9 3 9 10 5 9 10 10 8 9 10 10 4 5 1 4 3 10 2 10 4 5 8 10 2 2 7 2 10 2 6 4 10 1 1 1 1 2 3 10 1 10 2 8 1 5 9 4 3 1 10 8 1 8 1 9 5 6 7 2 9 10 1 6 7 4 8 8 7 3 5 7 10 10 ...
output:
89 77 80 74 75 84 75 105 143 95 81 74 78 73 73 73 83 93 90 84 79 77 73 89 77 73 81 79 80 175 83 77 83 76 83 85 84 97 74 80 101 74 113 74 75 95 75 83 86 77 99 73 77 83 91 96 77 80 77 76 80 81 73 95 83 74 75 81 77 79 74 76 78 81 97 77 85 73 92 83 73 80 73 77 74 73 142 83 99 78 91 77 76 81 77 74 78 76 ...
result:
wrong answer 1st numbers differ - expected: '97', found: '89'