#abc129c. [abc129_c]Typical Stairs

[abc129_c]Typical Stairs

問題文

NN 段の階段があります。高橋君は現在、上り口(00 段目)にいます。 高橋君は一歩で 11 段か 22 段上ることができます。

ただし、a1,a2,a3,....aMa_1,a_2,a_3,....a_M 段目の床は壊れており、その段に足を踏み入れることは危険です。

壊れている床を踏まないようにしながら、最上段(NN 段目)にたどりつくまでの移動方法は何通りあるでしょうか? 総数を 1,000,000,0071,000,000,007 で割った余りを求めてください。

制約

  • 1leqqNleqq1051 \\leqq N \\leqq 10^5
  • 0leqqMleqqN10 \\leqq M \\leqq N-1
  • 1leqqa1<a2<1 \\leqq a_1 < a_2 < ...... <aMleqqN1< a_M \\leqq N-1

入力

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

NN MM a1a_1 a2a_2 .. .. .. aMa_M

出力

条件を満たすような移動方法の総数を、1,000,000,0071,000,000,007 で割った余りを出力してください。


入力例 1

6 1
3

出力例 1

4

移動方法は以下の 44 通りです。

  • 0to1to2to4to5to60 \\to 1 \\to 2 \\to 4 \\to 5 \\to 6
  • 0to1to2to4to60 \\to 1 \\to 2 \\to 4 \\to 6
  • 0to2to4to5to60 \\to 2 \\to 4 \\to 5 \\to 6
  • 0to2to4to60 \\to 2 \\to 4 \\to 6

入力例 2

10 2
4
5

出力例 2

0

壊れている床を踏まないような移動方法がない場合もあります。


入力例 3

100 5
1
23
45
67
89

出力例 3

608200469

総数を 1,000,000,0071,000,000,007 で割った余りを出力することに注意して下さい。