QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#862021 | #2824. 找树 | strcmp | WA | 824ms | 31360kb | C++14 | 2.5kb | 2025-01-18 21:12:23 | 2025-01-18 21:12:26 |
Judging History
answer
#include <bits/stdc++.h>
#define X first
#define Y second
#define rep(i, a, b) for (int i = a; i <= b; i++)
#define per(i, a, b) for (int i = a; i >= b; i--)
#define pb push_back
#define mp make_pair
using namespace std;
typedef long long int ll;
using ull = unsigned long long int;
using pii = pair<int, int>;
using pli = pair<ll, int>;
using pq = priority_queue<int>;
using ld = double;
constexpr int maxn = 3e5 + 10, mod = 998244353, K = 40;
constexpr ll inf = 1e18; int n, m, a[75][75][4105], c[4105], len; char O[maxn]; ll b[75][75];
inline ll ksm(ll a, int b = mod - 2) {
ll ls = 1;
while (b) {
if (b & 1) ls = ls * a % mod;
a = a * a % mod; b >>= 1;
}
return ls;
}
void fwt(int* f, int n, int op) {
for (int i = 1, p = 1; p <= len; i <<= 1, p++) {
if (O[p] == '|') for (int j = 0; j < n; j += i << 1) rep(k, 0, i - 1) f[i + j + k] = (f[i + j + k] + (op == 1 ? f[j + k] : mod - f[j + k])) % mod;
else if (O[p] == '&') for (int j = 0; j < n; j += i << 1) rep(k, 0, i - 1) f[j + k] = (f[j + k] + (op == 1 ? f[i + j + k] : mod - f[i + j + k])) % mod;
else for (int j = 0; j < n; j += i << 1) rep(k, 0, i - 1) {
int u = f[j + k], v = f[i + j + k];
f[j + k] = (u + v) % mod, f[i + j + k] = (u - v) % mod;
if (op == -1) f[j + k] = (ll)f[j + k] * 499122177 % mod, f[i + j + k] = (ll)f[i + j + k] % 499122177 % mod;
}
}
}
ll det() {
ll ans = 1;
rep(i, 1, n - 1) {
rep(j, i + 1, n - 1) {
while (b[i][i]) {
ll w = b[j][i] / b[i][i];
rep(k, i, n - 1) b[j][k] = (b[j][k] - b[i][k] * w % mod + mod) % mod;
swap(b[i], b[j]); ans = mod - ans;
}
swap(b[i], b[j]); ans = mod - ans;
}
}
rep(i, 1, n - 1) ans = ans * b[i][i] % mod;
return ans;
}
int main() {
scanf("%d%d%s", &n, &m, O + 1); len = strlen(O + 1);
for (int i = 1, u, v, w; i <= m; i++) {
scanf("%d%d%d", &u, &v, &w);
a[u][u][w] = (a[u][u][w] + 1) % mod, a[v][v][w] = (a[v][v][w] + 1) % mod;
a[u][v][w] = (a[u][v][w] + mod - 1) % mod, a[v][u][w] = (a[v][u][w] + mod - 1) % mod;
}
rep(i, 1, n - 1) rep(i, 1, n - 1) fwt(a[i][i], 1 << len, 1);
rep(w, 0, 1 << len) {
rep(i, 1, n - 1) rep(j, 1, n - 1) b[i][j] = a[i][j][w];
c[w] = det();
}
fwt(c, 1 << len, -1);
per(i, (1 << len) - 1, 0) if (c[i]) printf("%d\n", i), exit(0);
puts("-1");
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 773ms
memory: 6144kb
input:
70 100 &&&&&&&&&&&& 59 1 577 11 18 513 41 11 6 7 33 1 25 26 577 3 57 516 28 5 3 13 56 0 2 32 7 66 53 517 42 31 519 41 34 70 37 54 579 24 15 512 70 32 512 51 49 64 55 19 69 3 31 517 24 8 582 44 45 513 47 58 517 47 41 577 33 22 519 57 41 0 70 50 67 3 6 6 14 43 6 21 1 579 32 27 576 62 7 514 39 36 69 12...
output:
-1
result:
ok single line: '-1'
Test #2:
score: 0
Accepted
time: 787ms
memory: 6016kb
input:
70 100 |&&&&|&&&^&& 70 50 200 51 46 9 48 33 163 14 64 137 53 54 96 32 24 160 7 22 8 40 66 192 12 22 74 20 25 66 7 40 97 27 13 192 3 15 96 43 16 195 23 6 74 7 34 33 5 5 98 12 26 99 44 38 8 27 44 32 10 67 42 19 12 234 6 39 65 27 24 8 58 13 106 37 69 32 4 2 163 33 65 168 3 3 107 56 65 8 42 53 137 32 53...
output:
-1
result:
ok single line: '-1'
Test #3:
score: -100
Wrong Answer
time: 824ms
memory: 31360kb
input:
70 5000 ^&&&&|^&^&&| 70 55 35 32 4 2338 1 45 33 69 4 2337 55 51 2338 26 46 2050 8 5 33 16 51 35 32 10 1 18 67 257 12 37 2307 34 6 2051 30 10 33 21 35 2082 4 27 34 12 4 2337 44 34 2082 11 17 2338 1 2 289 22 2 34 39 68 2304 11 48 289 44 26 2080 57 12 2306 69 15 2338 16 65 2 51 67 2048 1 5 291 64 48 28...
output:
2403
result:
wrong answer 1st lines differ - expected: '2339', found: '2403'