[HAOI2016] 字符合并
题目描述
有一个长度为 $n$ 的 $01$ 串,你可以每次将相邻的 $k$ 个字符合并,得到一个新的字符并获得一定分数。
得到的新字符和分数由这 $k$ 个字符确定。你需要求出你能获得的最大分数。
输入输出格式
输入格式
输入的第一行是两个整数,分别代表字符串长度 $n$ 和参数 $k$。
输入的第二行有 $n$ 个用空格隔开的非零即一的字符,第 $i$ 个字符表示初始串的第 $i$ 个字符。。
第 $3$ 到第 $(2^k + 2)$ 行,每行有一个字符和一个整数,第 $(i + 2)$ 行的字符 $c_i$ 个整数 $w_i$ 表示长度为 $k$ 的 $01$ 串连成二进制后按从小到大顺序得到的第 $i$ 种合并方案得到的新字符, $w_i$ 表示对应的第 $i$ 种方案对应获得的分数。
输出格式
输出一个整数表示答案。
输入输出样例
输入样例 #1
3 2
1 0 1
1 10
1 10
0 20
1 30
输出样例 #1
40
说明
#### 数据规模与约定
对于 $100\%$ 的数据,保证:
- $1\leq n\leq 300$,$1 \lt k \leq 8$。
- $c_i\in\{0,1\}$,$1 \leq w_i \leq 10^9$。