题目描述
N 段の階段があります。高橋君は現在、上り口(0 段目)にいます。 高橋君は一歩で 1 段か 2 段上ることができます。
ただし、a1,a2,a3,....aM 段目の床は壊れており、その段に足を踏み入れることは危険です。
壊れている床を踏まないようにしながら、最上段(N 段目)にたどりつくまでの移動方法は何通りあるでしょうか? 総数を 1,000,000,007 で割った余りを求めてください。
输入格式
入力は以下の形式で標準入力から与えられます。
N M a1 a2 . . . aM
输出格式
条件を満たすような移動方法の総数を、1,000,000,007 で割った余りを出力してください。
题目大意
有 n 级台阶,有 m 级台阶不能走,分别为 a1…am 级台阶。
现在你要从第 0 级台阶出发,每次可以向上一格或两格,求走到第 n 级台阶的方案数 mod109+7 的结果。
1≤n≤105,0≤m≤n−1,1≤a1<a2<…am≤n−1。
6 1
3
4
10 2
4
5
0
100 5
1
23
45
67
89
608200469
提示
制約
- 1 ≦ N ≦ 105
- 0 ≦ M ≦ N−1
- 1 ≦ a1 ...
Sample Explanation 1
移動方法は以下の 4 通りです。 - 0 → 1 → 2 → 4 → 5 → 6 - 0 → 1 → 2 → 4 → 6 - 0 → 2 → 4 → 5 → 6 - 0 → 2 → 4 → 6
Sample Explanation 2
壊れている床を踏まないような移動方法がない場合もあります。
Sample Explanation 3
総数を 1,000,000,007 で割った余りを出力することに注意して下さい。