蓝桥杯 10. 安全序列

当然可以,以下是整理后的 Markdown 格式题目描述:


题目描述

小蓝是工厂里的安全工程师,他负责安放工厂里的危险品。

工厂是一条直线,直线上有 n 个空位,小蓝需要将若干个油桶放置在这 n 个空位上。每 2 个油桶中间至少需要 k 个空位隔开

现在小蓝想知道,有多少种放置油桶的方案。你可以编写一个程序帮助他吗?

由于这个结果可能非常大,你的输出结果需要对 10^9 + 7 取模。


输入格式

  • 第一行包含两个正整数 nk,分别表示空位数量和每两个油桶之间至少要隔开的空位数。

输出格式

  • 输出共 1 行,包含 1 个整数,表示放置油桶的方案数,对 10^9 + 7 取模。

样例输入

in 复制代码
4 2

样例输出

out 复制代码
6

说明

使用 0 表示不放油桶,1 表示放油桶。

合法的 6 种放置方案如下:

in 复制代码
0000
1000
0100
0010
0001
1001

数据范围

  • 1 ≤ n ≤ 10^6
  • 1 ≤ k ≤ n

c++代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int main() {
    int n, k, mod = 1e9 + 7;
    cin >> n >> k;
    vector<int> dp(n + 1, 0);
    for (int i = 1; i <= n; i++) {
        dp[i] += (i - k - 1 >= 1) ? dp[i - k - 1] : 1;//放
        dp[i] += (i - 1 >= 1) ? dp[i - 1] : 1;//不放
        dp[i] %= mod;
    }
    cout << dp[n];
    return 0;
}//by wqs
相关推荐
C雨后彩虹2 小时前
任务最优调度
java·数据结构·算法·华为·面试
少林码僧4 小时前
2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法
人工智能·python·算法·机器学习·ai·数据挖掘
钱彬 (Qian Bin)4 小时前
项目实践15—全球证件智能识别系统(切换为Qwen3-VL-8B-Instruct图文多模态大模型)
人工智能·算法·机器学习·多模态·全球证件识别
微露清风4 小时前
系统性学习C++-第十八讲-封装红黑树实现myset与mymap
java·c++·学习
Niuguangshuo5 小时前
EM算法详解:解密“鸡生蛋“的机器学习困局
算法·机器学习·概率论
a3158238065 小时前
Android 大图显示策略优化显示(一)
android·算法·图片加载·大图片
CSARImage5 小时前
C++读取exe程序标准输出
c++
一只小bit5 小时前
Qt 常用控件详解:按钮类 / 显示类 / 输入类属性、信号与实战示例
前端·c++·qt·gui
一条大祥脚5 小时前
26.1.9 轮廓线dp 状压最短路 构造
数据结构·c++·算法
鲨莎分不晴5 小时前
反向传播的数学本质:链式法则与动态规划的完美共舞
算法·动态规划