#ARC112F. [ARC112F] Die Siedler

[ARC112F] Die Siedler

配点 : 900900

問題文

すぬけくんはカード 11 からカード nnnn 種類のカードを使うゲームで遊んでいます。 このゲームには、カードパックが mm 種類存在し、ii 種類目のカードパックにはカード jjsi,js_{i,j} 枚含まれています。 どのカードパックにもカードが 11 枚以上含まれています。

最初、すぬけくんはカード jjcjc_j 枚持っています(合計で 11 枚以上のカードを持っていることが保証されます)。

すぬけくんは、次の操作を好きな順番で好きな回数行うことができます。

  • カードパックをもらう:i=1,,mi=1,\dots,m のうちひとつを選ぶ。ii 種類目のパックに含まれるカードをすべて手に入れる。
  • カードを交換する:j=1,,nj=1,\dots,n のうちひとつを選ぶ。カード jj2j2j 枚捨てて、カード ((j mod n)+1)((j \text{ mod } n) + 1)11 枚手に入れる。(カード jj2j2j 枚以上持っていなければならない。)

すぬけくんは持っているカードの総数をできるだけ少なくしたいです。すぬけくんが達成できるカードの総数の最小値を求めてください。

制約

  • 2n162 \le n \le 16
  • 1m501 \le m \le 50
  • 0si,j,cj<2j0 \le s_{i,j}, c_j \lt 2j
  • c1++cn>0c_1+\dots +c_n>0
  • si,1++si,n>0s_{i,1}+\dots +s_{i,n}>0

入力

入力は以下の形式で標準入力から与えられる。

nn mm

c1c_1 \dots cnc_n

s1,1s_{1,1} \dots s1,ns_{1,n}

\vdots

sm,1s_{m,1} \dots sm,ns_{m,n}

出力

すぬけくんが達成できるカードの総数の最小値を出力せよ。

3 1
0 3 5
0 1 0
1

カード 11a1a_1 枚、カード 22a2a_2 枚、カード 33a3a_3 枚持っていることを (a1,a2,a3)(a_1, a_2, a_3) と書くことにします。 以下のように操作をすると、カードの総数を 11 枚にすることができます。

  • 11 種類目のカードパックをもらう。(0,4,5)(0,4,5) となる。
  • j=2j=2 を選んでカードを交換する。(0,0,6)(0,0,6) となる。
  • j=3j=3 を選んでカードを交換する。(1,0,0)(1,0,0) となる。

カードの総数を 00 枚にすることはできないため、これが最小です。

5 2
0 0 1 7 0
0 3 2 0 0
1 0 4 0 0
2

22 種類目のカードパックを 22 パックもらったあと、11 種類目のカードパックをもらい、その後何度かカードを交換すると、 カード 44 とカード 5511 枚ずつ持っている状態が作れます。

12 10
0 2 4 4 1 5 6 8 0 9 18 19
1 2 4 3 4 0 6 10 9 18 5 7
0 3 0 1 1 4 11 13 9 19 9 10
1 2 4 1 5 8 1 6 15 0 11 1
0 2 0 6 9 3 13 14 16 9 14 14
1 3 2 5 6 1 9 7 1 7 6 22
0 0 4 5 2 3 8 3 13 14 17 4
0 3 3 4 0 7 0 9 14 2 17 14
0 2 4 1 3 3 3 14 17 6 15 13
0 0 1 0 1 0 4 5 9 4 17 17
1 2 1 3 5 7 0 13 7 6 1 0
9