蓝桥杯破损的楼梯

状态转移方程

dp[i] = dp[i-1] + dp[i-2]

前提是dp[i-1]不是-1,dp[i-2]不是-1

代码

java 复制代码
import java.util.Scanner;

public class Main{

   public static void main(String[] args) {
       Scanner s = new Scanner(System.in);
       long mod = (long)1e9+7;
       long[] dp = new long[100010];
       int N = s.nextInt();
       int M = s.nextInt();
       for(int i=0;i<M;i++)
           dp[s.nextInt()]=-1;
       dp[0]=1;
       for(int i=1;i<=N;i++){
           if(dp[i]==-1)
               continue;
           if(i>=1 && dp[i-1]!=-1)
               dp[i] = (dp[i]+dp[i-1])%mod;
           if(i>=2 && dp[i-2]!=-1)
               dp[i] = (dp[i]+dp[i-2])%mod;

       }
       if(dp[N]==-1)//这个测试点很无语
         System.out.println(0);
       else
         System.out.println(dp[N]);
       s.close();
   }
}
相关推荐
ChoSeitaku38 分钟前
NO.80十六届蓝桥杯备战|数据结构-字符串哈希|兔子与兔子(C++)
数据结构·蓝桥杯·哈希算法
TT哇1 小时前
【前缀和】矩阵区域和(medium)
java·线性代数·算法·矩阵
lzb7591 小时前
第16届蓝桥杯单片机模拟试题Ⅲ
职场和发展·蓝桥杯
Elendill2 小时前
【算法笔记】并查集详解
笔记·python·算法
BanyeBirth2 小时前
C++高精度算法(加、减、乘)
开发语言·c++·算法
houliabc2 小时前
C语言个人笔记
c语言·数据结构·笔记·算法
年轮不改3 小时前
第十一届 蓝桥杯 嵌入式 省赛
蓝桥杯
Allen Wurlitzer3 小时前
算法刷题记录——LeetCode篇(1.9) [第81~90题](持续更新)
算法·leetcode·职场和发展
@MrLiu3 小时前
# 深度学习中的优化算法详解
人工智能·深度学习·算法·优化器
阳洞洞3 小时前
leetcode 377. Combination Sum IV
算法·leetcode·动态规划·完全背包问题