CF2170E Binary Strings and Blocks

题目描述

定义二进制串(仅由字符 $0$ 和/或 $1$ 组成的字符串)中的“块”为:一段由相同字符组成、且无法继续向左或向右扩展的连续子串。例如,在字符串 $110001111$ 中,有三个块: - 11(第 $1$ 位到第 $2$ 位); - 000(第 $3$ 位到第 $5$ 位); - 1111(第 $6$ 位到第 $9$ 位)。 例如,第 $7$ 位到第 $9$ 位的 111 不是一个块,因为可以向左扩展;第 $1$ 位到第 $5$ 位的 11000 不是块,因为其中包含了不同的字符。 我们称一个字符串为“美丽的”,如果存在一种方法,删除恰好一个块后,剩余部分的块数为奇数。例如: - 字符串 $110001111$ 是美丽的,因为可以去掉第 $3$ 到第 $5$ 位的块,剩下 $111111$,只有一个块; - 字符串 $1010$ 是美丽的,因为可以去掉第 $1$ 位的块,得到 $010$,共有三个块; - 字符串 $0000$ 不是美丽的,因为唯一能删除的块后字符串为空,块数为 $0$。 现在给定一个整数 $n$ 和 $m$ 个约束条件,第 $i$ 个约束用整数对 $l_i, r_i$ 描述。记字符串 $s$ 的第 $l$ 位到第 $r$ 位为 $s[l:r]$,即 $s[l:r]=s_l s_{l+1} \dots s_r$。你的任务是,统计长度为 $n$ 的二进制串 $s$,满足: - 对于每个 $i$($1 \le i \le m$),$s[l_i:r_i]$ 是美丽的。

输入格式

第一行一个整数 $t$($1 \le t \le 10^4$),表示测试用例个数。 每组测试的第一行包含两个整数 $n$ 和 $m$($2 \le n \le 3 \cdot 10^5$;$1 \le m \le 3 \cdot 10^5$),分别表示字符串长度和约束的数量。 接下来 $m$ 行,每行两个整数 $l_i, r_i$($1 \le l_i < r_i \le n$),表示第 $i$ 个约束的区间。 额外条件: - 所有测试用例中 $n$ 之和不超过 $3 \cdot 10^5$; - 所有测试用例中 $m$ 之和不超过 $3 \cdot 10^5$。

输出格式

对每组测试,输出一行一个整数,表示满足要求的字符串数。由于答案可能很大,输出结果对 $998244353$ 取模。

说明/提示

在题目的第一个例子中,满足条件的字符串有:1010 和 0101。对于这两个字符串,$s[1:2]$、$s[2:3]$、$s[3:4]$ 都是美丽的。 由 ChatGPT 5 翻译