Submission #70574656


Source Code Expand

Copy
#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);
 
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
#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
AC × 3
AC × 40
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


2025-10-31 (Fri)
22:26:03 +09:00