101424: [AtCoder]ABC142 E - Get Everything

Memory Limit:256 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Score : $500$ points

Problem Statement

We have $N$ locked treasure boxes, numbered $1$ to $N$.

A shop sells $M$ keys. The $i$-th key is sold for $a_i$ yen (the currency of Japan), and it can unlock $b_i$ of the boxes: Box $c_{i1}$, $c_{i2}$, $...$, $c_{i{b_i}}$. Each key purchased can be used any number of times.

Find the minimum cost required to unlock all the treasure boxes. If it is impossible to unlock all of them, print $-1$.

Constraints

  • All values in input are integers.
  • $1 \leq N \leq 12$
  • $1 \leq M \leq 10^3$
  • $1 \leq a_i \leq 10^5$
  • $1 \leq b_i \leq N$
  • $1 \leq c_{i1} < c_{i2} < ... < c_{i{b_i}} \leq N$

Input

Input is given from Standard Input in the following format:

$N$ $M$
$a_1$ $b_1$
$c_{11}$ $c_{12}$ $...$ $c_{1{b_1}}$
$:$
$a_M$ $b_M$
$c_{M1}$ $c_{M2}$ $...$ $c_{M{b_M}}$

Output

Print the minimum cost required to unlock all the treasure boxes. If it is impossible to unlock all of them, print $-1$.


Sample Input 1

2 3
10 1
1
15 1
2
30 2
1 2

Sample Output 1

25

We can unlock all the boxes by purchasing the first and second keys, at the cost of $25$ yen, which is the minimum cost required.


Sample Input 2

12 1
100000 1
2

Sample Output 2

-1

We cannot unlock all the boxes.


Sample Input 3

4 6
67786 3
1 3 4
3497 1
2
44908 3
2 3 4
2156 3
2 3 4
26230 1
2
86918 1
3

Sample Output 3

69942

Input

题意翻译

有 $N$ 个上锁的宝箱,编号为 $1$ 到 $N$。 商店出售 $M$ 把钥匙,第 $i$ 把钥匙锁需要的代价为 $a_i$,能解锁 $b_i$ 个箱子,编号分别是 $c_{i,1},c_{i,2},c_{i,3}…c_{i,b_i}$ 。 需要注意的是,钥匙一旦购买可以多次使用。 现在想打开所有的箱子,请问最小代价是多少。 如果不可能全部打开,直接输出 `-1`。

加入题单

算法标签: