上台阶
题目描述
有一楼梯共m级,刚开始时你在第一级,若每次只能跨上一级或二级,要走上第m级,共有多少走法?
注:规定从一级到一级有0种走法。
输入
输入数据首先包含一个整数n(1<=n<=100),表示测试实例的个数,然后是n行数据,每行包含一个整数m,(1<=m<=40), 表示楼梯的级数。
样例输入
2
2
3
输出
对于每个测试实例,请输出不同走法的数量。
样例输出
1
2
时间限制
C/C++语言:2000MS其它语言:4000MS
内存限制
C/C++语言:65537KB其它语言:589825KB 在赛码网做算法题,遇到这样一个问题。 虽然我还很一般,还需要继续进步,但是希望能够记录下学习的新知识。
把握自己的思想写下来,提供给没有想法的伙伴们一个参考~ 代码捉襟见肘,还请见谅~ 这是一个动态规划问题。
动态规划的特点是,一个庞大的问题我们可以把它分成多个阶段,每个阶段得到一个结果作为下一个阶段的开始。
  但是每个阶段都有多种可能性,每一种决策会影响当前的结果但是对下一阶段是没有影响的,阶段之间相互独立,只选择决策自己。 下面说一下我的思路: 当前我们站在1台阶 输入一个m 代表目标台阶
1 如果m是1 则 答案是0种
2 如果m是2 只有一种可能:1步上去 则答案是1种
3 如果m是3 两种可能:两次1步;一次2步 则答案是2种 4 如果m是4 有两种情况到达4 从2迈2台阶到4; 从3迈1台阶到4, 从1到2有1种、1到3有2种,所以 我们把这两种情况加在一起 1+2 答案是3种
5 如果m是5 有两种情况到达4 从3迈2台阶到5; 从4迈1台阶到5; 从1到4有3种、1到3有2种 所以 我们把这两种情况加在一起 3+2 答案是5种
......
之后都是一样的,我们从一开始往后推算,任何一个台阶都可以从上一个台阶迈1台阶 或者 上两个台阶 迈两个台阶过来,从1台阶到 前一台阶或者前两台阶都计算过。我们把两种情况相加就是这个目标的答案。 这就是很典型的动态规划算法的思想了:
请看代码,
python3版本:
 #coding:utf8
def count(steps):
if steps == 1:
return 0
if steps == 2:
return 1
if steps == 3:
return 2
return count(steps -1) + count(steps -2)
if __name__ == '__main__':
m = int(input())
for i in range(m):
n = int( input() )
print( count(n) )

鉴于python的使用量还不够庞大,我又用c写了一遍相同的实现。

C语言版本:
 int count( steps ){
if( steps == ) return ;
if( steps == ) return ;
if( steps == ) return ;
return count(steps - )+ count(steps -);
}
int main(){
int n,m;
scanf("%d",&n);
while( n-- ){
scanf("%d",&m);
printf("%d\n",count(m));
}
return ;
}

这两种语言实现相同的思想。不用纠结哪种语言。

不过经历了上面的分析,我们发现,每次台阶的结果都是前两个台阶结果的加和!!

这不禁让我们联想到斐波那契数,斐波那契数就是 前两项都是1,从第三项开始,每一项都是前两项加和。

所以用生成斐波那契数的方法来实现:

python版本:

 #斐波那契数列实现:
def getResult(n):
i = 2
num1 = 1
num2 = 1
while i <= n:
num1, num2 = num2, num1 + num2
i += 1
print(num1)
if __name__ == '__main__':
m = int(input())
for i in range(m):
n = int(input())
getResult(n)

能力一般~~请多包涵~

希望对大家有帮助!


赛码网算法: 上台阶 ( python3实现 、c实现)的更多相关文章

  1. 赛码网算法: 军训队列( python实现 )

    军训队列 题目描述某大学开学进行军训队列训练,将学生从一开始按顺序依次编号,并排成一行横队,训练的规则如下:从头开始一至二报数,凡报到二的出列剩下的依次向前靠拢,再从头开始进行一至三报数,凡报到三的出 ...

  2. 【JavaScript】赛码网前端笔试本地环境搭建

    参考:https://hoofoo.me/article/2017-04-11/%E8%B5%9B%E7%A0%81%E7%BD%91%E5%89%8D%E7%AB%AF%E7%AC%94%E8%AF ...

  3. ACM 五一杭电赛码"BestCoder"杯中国大学生程序设计冠军赛小记

    对于这项曾经热爱的竞赛,不得不说这是我最后一年参加ACM比赛了,所以要珍惜每一次比赛的机会. 五一去杭电参加了赛码"BestCoder"杯中国大学生程序设计冠军赛,去的队伍包括了今 ...

  4. 并查集+拓扑排序 赛码 1009 Exploration

    题目传送门 /* 题意:无向图和有向图的混合图判环: 官方题解:首先对于所有的无向边,我们使用并查集将两边的点并起来,若一条边未合并之前, 两端的点已经处于同一个集合了,那么说明必定存在可行的环(因为 ...

  5. 递推DP 赛码 1005 Game

    题目传送门 /* 递推DP:官方题解 令Fi,j代表剩下i个人时,若BrotherK的位置是1,那么位置为j的人是否可能获胜 转移的时候可以枚举当前轮指定的数是什么,那么就可以计算出当前位置j的人在剩 ...

  6. 数学 赛码 1010 GCD

    题目传送门 /* 数学:官方题解 首先,数组中每个元素至少是1 然后对于任意一个询问Li, Ri, Ansi, 说明Li ~ Ri中的元素必定是Ansi的倍数,那么只需将其与Ansi取最小公倍数即可 ...

  7. 贪心 赛码 1001 Movie

    题目传送门 /* 贪心:官方题解: 首先我们考虑如何选择最左边的一个区间 假设最左边的区间标号是i, 那选择的另外两个区间的左端点必定要大于Ri 若存在i之外的j, 满足Rj<Ri, 那么另外两 ...

  8. gcc和g++的区别【转自中国源码网】

    gcc和g++的区别[转自中国源码网] gcc和g++都是GNU(组织)的一个编译器. 误区一:gcc只能编译c代码,g++只能编译c++代码两者都可以,但是请注意:1.后缀为.c的,gcc把它当作是 ...

  9. PHP CRC16 校验码的算法怎么使用

    PHP CRC16 校验码的算法如何使用最近用到CRC16, 我现在就是要把 010301180001 算出CRC16的校验码,通过其他工具,可以得到 校验码是 05F1 最后完整的代码就是 0103 ...

随机推荐

  1. Android库项目中的资源ID冲突

    1.前言 Android Studio对模块化开发提供的一个很有用的功能就是可以在主项目下新建库项目(Module),但是在使用库项目时却有一个问题就是资源ID冲突,因为编译时SDK会自动帮我们处理这 ...

  2. Java-Integer源码分析

    除了两种浮点型,剩下的几种基本数据类型的包装类几乎都实现了常量池,有好处用数据的时候直接去拿,没有再去创建,坏处是在程序编译的时候就存入大量数据不管用不用到.下面是一篇很好的文章,很详细,转自:htt ...

  3. 笔记:MyBatis XML配置-Settings 完整属性表

    设置参数 描述 有效值 默认值 cacheEnabled 该配置影响的所有映射器中配置的缓存的全局开关. true | false true lazyLoadingEnabled 延迟加载的全局开关. ...

  4. WebPack介绍

    一.Webpack 是什么 Webpack 是德国开发者 Tobias Koppers 开发的模块加载器,Instagram 工程师认为这个方案很棒, 似乎还把作者招过去了.在 Webpack 当中, ...

  5. 将 Shiro 作为应用的权限基础 二:基于SpringMVC实现的认证过程

    认证就是验证用户身份的过程.在认证过程中,用户需要提交实体信息(Principals)和凭据信息(Credentials)以检验用户是否合法.最常见的“实体/凭证”组合便是“用户名/密码”组合. 一. ...

  6. java基础笔记(2)----流程控制

    java流程控制结构包括顺序结构,分支结构,循环结构. 顺序结构: 程序从上到下依次执行,中间没有任何判断和跳转. 代码如下: package com.lvsling.test; public cla ...

  7. MaxPooling的作用

    maxpooling主要有两大作用 1. invariance(不变性),这种不变性包括translation(平移),rotation(旋转),scale(尺度)2. 保留主要的特征同时减少参数(降 ...

  8. drbd(二):配置和使用

    本文目录:1.drbd配置文件2.创建metadata区并计算metadata区的大小3.启动drbd4.实现drbd主从同步5.数据同步和主从角色切换6.drbd脑裂后的解决办法7.drbd多卷组配 ...

  9. Property 'id' not found on type java.lang.String

    改为 忘写了$符,取不出来,因此报错!

  10. Vue.js学习

    <!DOCTYPE html> <html> <head> <title>xxx</title> </head> <bod ...