蓝桥杯 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++]洛谷B3626 跳跃机器人(题干 + 详细讲解, BFS练习题)
开发语言·c++·算法·bfs·广度优先
ThE.wHIte.18 分钟前
leetcode 3068. 最大节点价值之和
算法·leetcode·职场和发展
鸡鸭扣24 分钟前
leetcode hot100:十四、解题思路大全:真·大全!
数据结构·python·算法·leetcode·力扣·笔试
kyle~30 分钟前
C/C++---隐式显式转换
c语言·开发语言·c++
四谷夕雨33 分钟前
C++八股 —— 手撕定时器
开发语言·c++
Java永无止境38 分钟前
JAVASE:常见的算法
java·开发语言·数据结构·算法·排序算法
四谷夕雨2 小时前
C++八股 —— 手撕shared_ptr
开发语言·c++
猎板PCB厚铜专家大族2 小时前
2025有铜半孔工艺参数设计规范
网络·算法·设计规范
十五年专注C++开发2 小时前
CMake指令:add_library()
开发语言·c++·cmake·自动化编译工具
白熊1882 小时前
【图像大模型】AnimateDiff:基于扩散模型的视频生成技术解析与实践指南
人工智能·算法·音视频