【蓝桥杯选拔赛真题44】C++找路线 第十四届蓝桥杯青少年创意编程大赛 算法思维 C++编程选拔赛真题解析

目录

C++找路线

一、题目要

1、编程实现

2、输入输出

二、算法分析

三、程序编写

四、程序说明

五、运行结果

六、考点分析

七、推荐资料


C++找路线

第十四届蓝桥杯青少年创意编程大赛C++选拔赛真题

一、题目要

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

二、算法分析

  1. 从给定题目的初步分析可以看出,题目看着很多,但其实认真分析难度不是很大
  2. 根据给定的图片可以看到,从第一名同学到每一名同学的路线总数符合斐波那契数列的
  3. 那从N到编号M,其实可以先转换为相对从1到对应的同学编号即可,如何转换,直接将M-N再加1就转换好了,然后就是求第几项斐波那契数列值就是我们对用的路线总数

三、程序编写

#include <iostream>
using namespace std;
int fn(int k)
{
	if (k == 1 || k == 2)
		return 1;
	else
		return fn(k-1) + fn(k-2);
}

int main(void) 
{
	int n,m,res;
	cin >> n >> m;
	res = fn(abs(m-n)+1);
	cout << res << endl;
}

四、程序说明

  1. 首先需要导入输入输出流头文件
  2. 接着再次导入输入输出流格式控制头文件
  3. 然后是引入std命名空间中的所有成员到当前的程序中,这样在当前的程序中就可以直接使用 std 命名空间中的所有成员,而不需要使用的时候在成员前面加上(std::)前缀
  4. 定义一个递归函数fn求斐波那契数列,当数字为1或者2的时候返回1
  5. 否则返回n-1个人的数量加上n-2个人的数量
  6. 接着声明程序的入口,也就是主函数(主函数在一个程序中只允许出现一次)
  7. 根据题目要求声明3个整型变量n,m和res,n和m表示输入的人数,res就是路线总数
  8. 然后利用输入流对象cin,从键盘读取变量n和m的值
  9. 调用递归函数fn,将m-n的绝对值加1作为参数传递,最后结果保存再res中
  10. 最后利用输出流对象cout,输出res的值
  11. 最后返回0,程序结束

 本文作者:小兔子编程 作者首页:https://blog.csdn.net/frank2102

五、运行结果

3 7
5

六、考点分析

难度级别:中等,这题相对而言还是有点难度,在于如何分析出斐波那契数列规律,具体主要考查如下:

  1. 充分掌握变量的定义和使用
  2. 学会斐波那契数列的原理和实现
  3. 学会输入流对象cin的使用,从键盘读入相应的数据
  4. 学会for循环的使用,在确定循环次数的时候推荐使用学会
  5. 学会while循环的使用,在不确定循环次数的时候推荐使用
  6. 学会if条件判断语句的使用,满足一定条件才能执行后面的语句
  7. 学会if...else...双分支语句的使用,条件满足执行一种处理,不满足执行另一种处理
  8. 学会abs函数的使用,返回当前对象的绝对值
  9. 掌握输出流对象cout的使用,与流插入运算符 << 结合使用将对象输出到终端显示
  10. 学会分析题目,算法分析,将复杂问题模块化,简单化,从中找到相应的解题思路
  11. 充分掌握变量定义和使用、分支语句、循环语句和简单算法知识的使用及输入输出的用法

PS:方式方法有多种,小朋友们只要能够达到题目要求即可!

七、推荐资料

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-03-23 15:52:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-23 15:52:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-23 15:52:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-23 15:52:02       20 阅读

热门阅读

  1. SpringDataJpa大坑——一对多级联修改问题

    2024-03-23 15:52:02       15 阅读
  2. v-for=“item in arr“ 的理解

    2024-03-23 15:52:02       19 阅读
  3. 24计算机考研调剂 | 西北民族大学

    2024-03-23 15:52:02       20 阅读
  4. 面试算法-79-搜索旋转排序数组

    2024-03-23 15:52:02       17 阅读
  5. Vue 面试题(二)

    2024-03-23 15:52:02       23 阅读
  6. 003-基于Jetson Nano平台的在线二维码检测

    2024-03-23 15:52:02       22 阅读
  7. C语言判断回⽂字符串

    2024-03-23 15:52:02       19 阅读
  8. MySQL知识总结

    2024-03-23 15:52:02       18 阅读
  9. Linux - IO

    2024-03-23 15:52:02       17 阅读
  10. capl实现crc校验码计算

    2024-03-23 15:52:02       20 阅读
  11. 蓝桥杯/减肥/c\c++

    2024-03-23 15:52:02       15 阅读
  12. LeetCode算法(一) 之 Python基础

    2024-03-23 15:52:02       20 阅读