Submission #70574656
Source Code Expand
Copy
#include <stdio.h>#define MOD_BY 998244353int add(int a, int b) {return a + b - MOD_BY * (a + b >= MOD_BY);}int sub(int a, int b) {return b == 0 ? a : add(a, MOD_BY - b);}int mul(int a, int b) {return (int)((long long)a * b % MOD_BY);}int pou(int a, int b) {int r = 1;while (b > 0) {if (b & 1) r = mul(r, a);a = mul(a, a);
#include <stdio.h>
#define MOD_BY 998244353
int add(int a, int b) {
return a + b - MOD_BY * (a + b >= MOD_BY);
}
int sub(int a, int b) {
return b == 0 ? a : add(a, MOD_BY - b);
}
int mul(int a, int b) {
return (int)((long long)a * b % MOD_BY);
}
int pou(int a, int b) {
int r = 1;
while (b > 0) {
if (b & 1) r = mul(r, a);
a = mul(a, a);
b >>= 1;
}
return r;
}
int bitcnt(int n) {
n = (n & 0x55555555) + ((n & 0x2aaaaaaa) >> 1);
n = (n & 0x33333333) + ((n & 0x4ccccccc) >> 2);
n = (n & 0x0f0f0f0f) + ((n & 0x70f0f0f0) >> 4);
n = (n & 0x00ff00ff) + ((n & 0x7f00ff00) >> 8);
n = (n & 0x0000ffff) + ((n & 0x7fff0000) >> 16);
return n;
}
int N, L;
char S[24][32];
int masks[24];
int pous[32];
int main(void) {
int i, j;
int ans = 0;
if (scanf("%d%d", &N, &L) != 2) return 1;
for (i = 0; i < N; i++) {
if (scanf("%31s", S[i]) != 1) return 1;
for (j = 0; S[i][j] != '\0'; j++) {
int idx = S[i][j] - 'a';
if (0 <= idx && idx < 26) masks[i] |= 1 << idx;
}
}
for (i = 0; i < 32; i++) {
pous[i] = pou(i, L);
}
for (i = 1; i < (1 << N); i++) {
int mask = 0x7fffffff;
for (j = 0; j < N; j++) {
if ((i >> j) & 1) mask &= masks[j];
}
ans = (bitcnt(i) % 2 == 0 ? sub : add)(ans, pous[bitcnt(mask)]);
}
printf("%d\n", ans);
return 0;
}
Submission Info
| Submission Time | |
|---|---|
| Task | F - typewriter |
| User | mikecat |
| Language | C (gcc 12.2.0) |
| Score | 500 |
| Code Size | 1349 Byte |
| Status | AC |
| Exec Time | 17 ms |
| Memory | 1732 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 500 / 500 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | sample_01.txt, sample_02.txt, sample_03.txt |
| All | sample_01.txt, sample_02.txt, sample_03.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt, test_21.txt, test_22.txt, test_23.txt, test_24.txt, test_25.txt, test_26.txt, test_27.txt, test_28.txt, test_29.txt, test_30.txt, test_31.txt, test_32.txt, test_33.txt, test_34.txt, test_35.txt, test_36.txt, test_37.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| sample_01.txt | AC | 1 ms | 1672 KiB |
| sample_02.txt | AC | 0 ms | 1724 KiB |
| sample_03.txt | AC | 1 ms | 1696 KiB |
| test_01.txt | AC | 1 ms | 1728 KiB |
| test_02.txt | AC | 1 ms | 1640 KiB |
| test_03.txt | AC | 1 ms | 1572 KiB |
| test_04.txt | AC | 0 ms | 1560 KiB |
| test_05.txt | AC | 1 ms | 1712 KiB |
| test_06.txt | AC | 1 ms | 1724 KiB |
| test_07.txt | AC | 1 ms | 1632 KiB |
| test_08.txt | AC | 1 ms | 1624 KiB |
| test_09.txt | AC | 1 ms | 1636 KiB |
| test_10.txt | AC | 1 ms | 1668 KiB |
| test_11.txt | AC | 0 ms | 1724 KiB |
| test_12.txt | AC | 0 ms | 1696 KiB |
| test_13.txt | AC | 0 ms | 1704 KiB |
| test_14.txt | AC | 1 ms | 1592 KiB |
| test_15.txt | AC | 1 ms | 1668 KiB |
| test_16.txt | AC | 9 ms | 1604 KiB |
| test_17.txt | AC | 1 ms | 1596 KiB |
| test_18.txt | AC | 1 ms | 1712 KiB |
| test_19.txt | AC | 1 ms | 1732 KiB |
| test_20.txt | AC | 1 ms | 1628 KiB |
| test_21.txt | AC | 17 ms | 1724 KiB |
| test_22.txt | AC | 1 ms | 1632 KiB |
| test_23.txt | AC | 2 ms | 1632 KiB |
| test_24.txt | AC | 1 ms | 1720 KiB |
| test_25.txt | AC | 17 ms | 1724 KiB |
| test_26.txt | AC | 17 ms | 1724 KiB |
| test_27.txt | AC | 17 ms | 1704 KiB |
| test_28.txt | AC | 17 ms | 1728 KiB |
| test_29.txt | AC | 17 ms | 1568 KiB |
| test_30.txt | AC | 17 ms | 1712 KiB |
| test_31.txt | AC | 17 ms | 1620 KiB |
| test_32.txt | AC | 17 ms | 1728 KiB |
| test_33.txt | AC | 17 ms | 1636 KiB |
| test_34.txt | AC | 17 ms | 1728 KiB |
| test_35.txt | AC | 17 ms | 1728 KiB |
| test_36.txt | AC | 17 ms | 1672 KiB |
| test_37.txt | AC | 17 ms | 1672 KiB |