软件补丁问题

题目描述

T 公司发现其研制的一个软件中有 $n$ 个错误,随即为该软件发放了 $m$ 个补丁程序。 每一个补丁程序都有其特定的适用环境,某个补丁只有在软件中包含某些错误而同时又不包含另一些错误时才可以使用。一个补丁在排除某些错误的同时,往往会加入另一些错误。 换句话说,对于任意一个补丁 $i$,都有四个与之相应的集合 $B1_i,B2_i,F1_i$ 和 $F2_i$。仅当软件包含 $B1_i$ 中的所有错误,而不包含 $B2_i$ 中的任何错误时,才可以使用补丁 $i$。补丁 $i$ 将修复软件中的某些错误集合 $F1_i$,而同时加入另一些错误 $F2_i$。另外,运行每个补丁都耗费一定的时间。 试设计一个算法,利用 T 公司提供的 $m$ 个补丁程序将原软件修复成一个没有错误的软件,并使修复后的软件耗时最少。对于给定的 $n$ 个错误和 $m$ 个补丁程序,找到总耗时最少的软件修复方案。

输入输出格式

输入格式


第一行有两个正整数 $n$ 和 $m$。$n$ 表示错误总数,$m$表示补丁总数。 接下来 $m$ 行给出了 $m$ 个补丁的信息。每行包括一个正整数,表示运行补丁程序 $i$ 所需时间,以及两个长度为 $n$ 的字符串。中间用一个空格符隔开。 第一个字符串中,如果第 $k$ 个字符为 ```+```,则表示第 $k$ 个错误属于 $B1_i$。若为 ```-```,则表示第 $k$ 个错误属于 $B2_i$。若为 ```0```,则第 $k$ 个错误既不属于 $B1_i$ 也不属于 $B2_i$,即软件中是否包含第 $k$ 个错误并不影响补丁 $i$ 的可用性。 第二个字符串中,如果第 $k$ 个字符为 ```-```,则表示第 $k$ 个错误属于 $F1_i$。若为 ```+```,则表示第 $k$ 个错误属于 $F2_i$。若为 ```0```,则第 $k$ 个错误既不属于 $F1_i$ 也不属于 $F2_i$,即软件中是否包含第 $k$ 个错误不会因使用补丁 $i$ 而改变。

输出格式


程序运行结束时,将总耗时数输出。如果问题无解,则输出 `0`。

输入输出样例

输入样例 #1

3 3
1 000 00-
1 00- 0-+
2 0-- -++

输出样例 #1

8

说明

对于 $100\%$ 的数据:$1\le n\le 20$,$1\le m\le 100$。