AT_arc171_d [ARC171D] Rolling Hash
题目描述
给定整数 $P,B$ 满足 $P$ 是质数,$1\le B\le P-1$。
对于序列 $X=(x_1,x_2,\cdots,x_n)$,定义 $\operatorname{hash}(X)$ 的值为
$$\operatorname{hash}(X)=\left(\sum_{i=1}^nx_iB^{n-i}\right)\bmod P$$
给定 $M$ 对整数 $(L_i,R_i)(1\le i\le M)$,请问是否存在长度为 $N$ 的序列 $A=(A_1,A_2,\cdots,A_N)$ 满足:
- 对每一个 $i(1\le i\le M)$,都有
$$\operatorname{hash}((A_{L_i},A_{L_i+1},\cdots,A_{R_i}))\not=0$$
输入格式
第一行四个整数 $P,B,N,M$,接下来 $M$ 行每行两个整数 $L_i,R_i$。
输出格式
若存在 $A$ 满足要求输出 `Yes`,否则输出 `No`。
### 样例 1 解释
序列 $A=(2,0,4)$ 满足要求。其中
- $\operatorname{hash}((A_1))=2$
- $\operatorname{hash}((A_1,A_2))=1$
- $\operatorname{hash}((A_2,A_3))=1$
说明/提示
- $2 \leq P \leq 10^9$
- $P$ 是质数。
- $1 \leq B \leq P - 1$
- $1 \leq N \leq 16$
- $1 \leq M \leq \frac{N(N+1)}{2}$
- $1 \leq L_i \leq R_i \leq N$
- $(L_i, R_i) \neq (L_j, R_j)$ if $i \neq j$.
- 所有的输入都是整数。