[蓝桥杯 2018 ]激光样式

激光样式

题目描述

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

X 星球的盛大节日为增加气氛,用 30 台机光器一字排开,向太空中打出光柱。

安装调试的时候才发现,不知什么原因,相邻的两台激光器不能同时打开! 国王很想知道,在目前这种 bug 存在的情况下,一共能打出多少种激光效果?

显然,如果只有 3 台机器,一共可以成 5 种样式,即: 全都关上(sorry, 此时无声胜有声,这也算一种);开一台,共 3 种;开两台,只 1 种。

30台就不好算了,国王只好请你帮忙了。

要求输出一个整数,表示 30 台激光器能形成的样式种数。

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 128M

总通过次数: 809 | 总提交次数: 834 | 通过率: 97%

难度: 中等 标签: 2018

思路分享:

当n为1时,sum=2;

当n为2时,sum=3;

当n为3时,sum=5;

当n为4时,sum=8;

..............................

所以可以发现,这个符合斐波那契数列的规律

代码分享:

cpp 复制代码
#include <iostream>
using namespace std;
int Fib(int n){
  if(n==1)
  return 2;
  if(n==2)
  return 3;
  return Fib(n-1)+Fib(n-2);
}
int main()
{
  int n=Fib(30);
  cout<<n;
  return 0;
}
相关推荐
Codiggerworld9 分钟前
从字节码到JVM:深入理解Java的“一次编写,到处运行”魔法
java·开发语言·jvm
14 分钟前
2.12矩阵问题,发牌,数字金字塔
线性代数·算法·矩阵
无聊的小坏坏21 分钟前
一文讲通:二分查找的边界处理
数据结构·c++·算法
m0_5287490021 分钟前
C语言错误处理宏两个比较重要的
java·linux·算法
禾叙_24 分钟前
【netty】Channel
开发语言·javascript·ecmascript
云深处@29 分钟前
【C++11】包装器,智能指针
开发语言·c++
十五年专注C++开发34 分钟前
CMake进阶:SelectLibraryConfigurations模块
c++·cmake·自动化构建
量子炒饭大师36 分钟前
【C++入门】Cyber深度漫游者的初始链路——【类与对象】初始化成员列表
开发语言·c++·dubbo·类与对象·初始化成员列表
TracyCoder12341 分钟前
LeetCode Hot100(50/100)——153. 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
诸葛务农41 分钟前
点云配准在人形机器人中的应用:ICP算法(2)
人工智能·算法·机器学习·机器人