目录
python找路线
一、题目要求
1、编程实现
2、输入输出
二、算法分析
三、程序编写
四、程序说明
五、运行结果
六、考点分析
七、 推荐资料
1、蓝桥杯比赛
2、考级资料
3、其它资料
python找路线
第十四届蓝桥杯青少年组python比赛选拔赛真题
一、题目要求
(注:input()输入函数的括号中不允许添加任何信息)
1、编程实现
现有 22 名小朋友,依次编号1到 22,22 名小朋友分别按照下图的位置站好。
每名小朋友只能按照图中箭头指向的方向移动。给出两名小朋友的编号 N和 M(1≤N<M≤22),
请你找出从编号 N 到编号 M 共有多少条不同的路线。
例如:N=3,M=7,从编号3的位置到编号7的位置共有5条路线,分别为:(3->5->7),(3->5->6->7),(3->4->5->7),(3->4->5->6>7),(3->4>6->7)
2、输入输出
输入描述:只有一行,输入两个正整数 N 和 M(1≤N<M≤22),分别表示两名小朋友的编号,之间以一个空格隔开。
输出描述:输出一个整数,表示从编号 N 到编号 M 共有多少条不同的路线。
输入样例:
3 7
输出样例:
5
二、算法分析
- 从给定题目的初步分析可以看出,题目看着很多,但其实认真分析难度不是很大
- 根据给定的图片可以看到,从第一名同学到每一名同学的路线总数符合斐波那契数列的
- 那从N到编号M,其实可以先转换为相对从1到对应的同学编号即可,如何转换,直接将M-N再加1就转换好了,然后就是求第几项斐波那契数列值就是我们对用的路线总数
三、程序编写
def fn(k):
if k==1 or k==2:
return 1
else:
return fn(k-1) + fn(k-2)
n,m = map(int,input().split())
res = fn(m-n+1)
print(res)
四、程序说明
- 定义一个递归函数fn求斐波那契数列,当数字为1或者2的时候返回1
- 否则返回k-1个人的数量加上k-2个人的数量
- 利用input输入函数,split函数,int函数以及map函数将输入人数保存到n和m变量中
- 然后调用递归函数fn并将m-n+1的值作为参数传入
- 最后通过print函数输出即可
五、运行结果
3 7
5
六、考点分析
难度级别:中等,这题相对而言还是有一点小难度,难在如何分析出斐波那契数列,具体主要考查如下:
- 学会分析题目,找到解题思路
- 学会简单的算法知识的应用
- input函数:Python 中 input() 函数接受一个标准输入数据,返回为 string 类型。
- int函数:强制将传入对象转换成整数类型
- split函数:按照指定的分隔符进行分割
- map函数:将指定的对象按照指定的函数进行迭代,在这里是将时分秒字符串类型数据按int整数类型数字返回输出(相当于多个变量强制类型转化)
- 学会while循环的使用:一般在不知道循环条件下推荐使用,条件不成立执行循环体,成立退出循环体
- 学会for循环的使用:for循环可以遍历任何有序的项及列表元素等等。
- range函数:rang(a,b),循环的时候是不包括b的,所以我们这个案例中要转变一下,要想包含b,就应该写成range(a,b+1)
- 学会if...条件判断语句的使用:满足条件才执行相应的程序
- 学会if...else双分支语句的使用:满足条件执行一种处理程序,不满足执行另一种处理程序
- print函数:用于打印输出,最常见的一个函数
- 充分掌握for循环和列表相关操作函数的使用
PS:方式方法有多种,小朋友们只要能够达到题目要求即可!
七、 推荐资料
- 所有考级比赛学习相关资料合集【推荐收藏】
1、蓝桥杯比赛
-
蓝桥杯python选拔赛真题详解
-
蓝桥杯python省赛真题详解
-
蓝桥杯python国赛真题详解
-
历届蓝桥杯科技素养计算思维真题解析
2、考级资料
-
python等级一级真题解析【电子学会】
-
python等级二级真题解析【电子学会】
-
python等级三级真题解析【电子学会】
-
python等级四级真题解析【电子学会】
3、其它资料
-
初学python100例
- 历届蓝桥杯scratch国赛真题解析
- 历届蓝桥杯scratch省赛真题解析
- 历届蓝桥杯scratch STEMA选拔赛真题解析
- 历届蓝桥杯科技素养计算思维真题解析
- 画图-scratch编程考级99图
- 电子学会历年scratch等级考试一级真题解析
- 电子学会历年scratch等级考试二级真题解析
- 电子学会历年scratch等级考试三级真题解析
- 电子学会历年scratch等级考试四级真题解析
- 零基础学习scratch3.0【入门教学 免费】
- 零基础学习scratch3.0【视频教程 114节 免费】