赛码网算法: 上台阶 ( python3实现 、c实现)
上台阶
题目描述
有一楼梯共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实现)的更多相关文章
- 赛码网算法: 军训队列( python实现 )
军训队列 题目描述某大学开学进行军训队列训练,将学生从一开始按顺序依次编号,并排成一行横队,训练的规则如下:从头开始一至二报数,凡报到二的出列剩下的依次向前靠拢,再从头开始进行一至三报数,凡报到三的出 ...
- 【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 ...
- ACM 五一杭电赛码"BestCoder"杯中国大学生程序设计冠军赛小记
对于这项曾经热爱的竞赛,不得不说这是我最后一年参加ACM比赛了,所以要珍惜每一次比赛的机会. 五一去杭电参加了赛码"BestCoder"杯中国大学生程序设计冠军赛,去的队伍包括了今 ...
- 并查集+拓扑排序 赛码 1009 Exploration
题目传送门 /* 题意:无向图和有向图的混合图判环: 官方题解:首先对于所有的无向边,我们使用并查集将两边的点并起来,若一条边未合并之前, 两端的点已经处于同一个集合了,那么说明必定存在可行的环(因为 ...
- 递推DP 赛码 1005 Game
题目传送门 /* 递推DP:官方题解 令Fi,j代表剩下i个人时,若BrotherK的位置是1,那么位置为j的人是否可能获胜 转移的时候可以枚举当前轮指定的数是什么,那么就可以计算出当前位置j的人在剩 ...
- 数学 赛码 1010 GCD
题目传送门 /* 数学:官方题解 首先,数组中每个元素至少是1 然后对于任意一个询问Li, Ri, Ansi, 说明Li ~ Ri中的元素必定是Ansi的倍数,那么只需将其与Ansi取最小公倍数即可 ...
- 贪心 赛码 1001 Movie
题目传送门 /* 贪心:官方题解: 首先我们考虑如何选择最左边的一个区间 假设最左边的区间标号是i, 那选择的另外两个区间的左端点必定要大于Ri 若存在i之外的j, 满足Rj<Ri, 那么另外两 ...
- gcc和g++的区别【转自中国源码网】
gcc和g++的区别[转自中国源码网] gcc和g++都是GNU(组织)的一个编译器. 误区一:gcc只能编译c代码,g++只能编译c++代码两者都可以,但是请注意:1.后缀为.c的,gcc把它当作是 ...
- PHP CRC16 校验码的算法怎么使用
PHP CRC16 校验码的算法如何使用最近用到CRC16, 我现在就是要把 010301180001 算出CRC16的校验码,通过其他工具,可以得到 校验码是 05F1 最后完整的代码就是 0103 ...
随机推荐
- 使用vlookup嵌套INDIRECT函数实现跨表数据引用
这是一个使用 vlookup 函数嵌套 INDIRECT 函数来实现跨工作表数据引用的教程. 某小学决定要抽查本校三年级三个班的期末考情况,抽查方法为在每个班中抽查5名学生,将这15名学生的期末考情况 ...
- 用js制作日期 2017-03-23
日期表: <body> <select id="year" ></select>年 <select id="month" ...
- kubernetes实践之运行aspnetcore webapi微服务
1.预备工作 unbuntu 16.04 and above docker kubernetes 集群 2.使用vs2017创建一个web api应用程序,并打包镜像到本地. 3.推送本地镜像到doc ...
- Nginx配置ThinkPHP下的url重写(隐藏入口)
搭建好项目后,在网址上输入域名,只能访问首页,其他页面全是404. 在域名后面和控制器前面加上index.php就可以访问. 在tp5官网手册查找后进行配置修改. 打开nginx.conf 后 ,在s ...
- 数据库MySQL、redis主从切换shell脚本
具体源码可找我领取
- linux截取字符串之sort、uniq、cut用法
sort命令是帮我们依据不同的数据类型进行排序 参 数: -b 忽略每行前面开始出的空格字符. -c 检查文件是否已经按照顺序排序. -f 排序时,忽略大小写字母. -M 将前 ...
- 设计模式 --> (7)外观模式
外观模式 外观模式为子系统中的一组接口提供一个一致的界面, 外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 适用性 1.为一个复杂子系统提供一个简单接口. 2.提高子系统的独立性. ...
- java基础--封装
封 装(面向对象特征之一):是指隐藏对象的属性和实现细节,仅对外提供公共访问方式. 好处:将变化隔离:便于使用:提高重用性:安全性. 封装原则:将不需要对外提供的内容都隐藏起来,把属性都隐藏,提供公共 ...
- 仿京东树形菜单插件hovertree
hovertree是一个仿京东的树形菜单jquery插件,暂时有银色和绿色两种. 官方网址:http://keleyi.com/jq/hovertree/欢迎下载使用 查看绿色效果:http://ke ...
- Hibernate学习笔记二
Hibernate持久化类的编写规则 Hibernate是持久层的ORM映射框架,专注于数据的持久化工作.所谓持久化,就是将内存中的数据永久存储到关系型数据库中. 持久化类 一个java类与数据库表建 ...