码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • P1192 台阶问题


    P1192 台阶问题

    题目详情

    有N级的台阶,你一开始在底部,每次可以向上迈最多K级台阶(最少1级),问到达第N级台阶有多少种不同方式。

    输入格式

    两个正整数N,K。

    输出格式

    一个正整数,为不同方式数,由于答案可能很大,你需要输出ans mod100003后的结果。

    输入输出样例

    输入 #1

    5 2
    
    • 1

    输出 #1

    8
    
    • 1

    说明/提示

    对于20%20%的数据,有N ≤ 10, K ≤ 3N≤10,K≤3;

    对于40%40%的数据,有N ≤ 1000N≤1000;

    对于100%100%的数据,有N ≤ 100000,K ≤ 100N≤100000,K≤100。

    思路

    由于每次能跳的台阶不确定,所以一开始没有思路。后来列出了好多数据,发现了规律。

    k=2 : 1 2 3 5 8 13 21 34…
    k=3 : 1 2 4 7 13 24 44 81…
    k=4 : 1 2 4 8 15 29 56 108…
    k=5 : 1 2 4 8 16 31 61 120…

    仔细观察我们就会发现,越往后面越像等差数列,当k越大,整个数据就趋向于他。

    规律:
    当n<=k时,第N项=(上一项2)%100003;
    当n>k时 ,第N项=(上一项
    2-第n-1-k项)%100003;

    到了这一部题目就变得简单了。

    代码详情

    #include
    #include
    using namespace std;
    const int mod=100003;
    int n,k,a[1000000],ans=0;
    int main()
    {
    	cin>>n>>k;
    	a[0]=a[1]=1;
    	for(int i=2;i<=n;++i)
    	{
    		if(i<=k)
    		{
    			a[i]=(a[i-1]*2)%mod;
    		}
    		else 
    		{
    			a[i]=(a[i-1]*2-a[i-k-1])%mod;
    		}
    	}
    	ans=(a[n]+mod)%mod;
        cout<<ans;
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
  • 相关阅读:
    11.25日常总结
    spring cloud gateway整合security实现统一权鉴
    Linux 系统执行ls 命令出现 Input/output error 解决妙招
    关于使用鼠标时间mouseMove拖拽元素及元素抖动的解决方案
    Node.js【模块的加载机制、初识 Express、Express 路由】
    Git工作流
    C进阶—动态内存管理
    Vue.js之Vuex的使用
    conda存在环境但是无法使用名字激活
    java计算机毕业设计数据分析星辰网智能手机销售网站源码+系统+mysql数据库+lw文档+部署
  • 原文地址:https://blog.csdn.net/zjsru_Beginner/article/details/126068052
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号