当前位置: 首页 > 编程笔记 >

计算O(Log n)时间中给定范围内的斐波那契数和C ++中O(1)空间中的斐波那契数

於和志
2023-03-14
本文向大家介绍计算O(Log n)时间中给定范围内的斐波那契数和C ++中O(1)空间中的斐波那契数,包括了计算O(Log n)时间中给定范围内的斐波那契数和C ++中O(1)空间中的斐波那契数的使用技巧和注意事项,需要的朋友参考一下

给定具有开始和结束编号的范围,任务是计算在O(Log n)时间和O(1)空间中给定范围之间可用的斐波那契数的总数。

什么是斐波那契数

斐波那契数是称为斐波那契数列的数字序列,其中每个新数字都是前两个数之和。

其中,f= 0和f(1)= 1,即f和f(1)在序列中具有固定位置,并且计算将从第三个数字开始。

用于计算序列的公式是-

F n = F n-1 + F n-2

哪里,

F 0 = 0,F 1 = l

例如

Input − start = 6 and last = 100Output − Number of fibonacci Numbers in the series are 6

说明-6到100之间的斐波那契数是8、13、21、34、55、89,即总数为6

Input − start = 0 and last = 8Output − Number of fibonacci Numbers in the series are 7

说明-0和8之间的斐波那契数是0、1、1、2、3、5、8,即总数为7

以下程序中使用的方法如下

  • 输入开始和结束编号以创建范围

  • 声明并初始化fib1到0,fib2到1,fib3到1

  • 声明一个临时变量res并将其初始化为0

  • 当fib1小于或等于end时,开始循环

  • 在循环内部,检查fib1是否大于或等于起点,然后将res增加1

  • 将fib1设置为fib2,将fib2设置为fib3,将fib3设置为fib1 + fib2

  • 返回资源

  • 打印结果

示例

#include <bits/stdc++.h>
using namespace std;
// function to count fibonacci numbers in range
// from start to last
int count_fibonacci(int start, int last){
   // First three Fibonacci Numbers
   int fib1 = 0, fib2 = 1, fib3 = 1;
   // res to count the number of fibonacci
   int res = 0;
   while (fib1 <= last){
      if (fib1 >= start){
         res++;
      }
      fib1 = fib2;
      fib2 = fib3;
      fib3 = fib1 + fib2;
   }
   return res;
}
// main function
int main(){
   int start = 6, last = 100;
   cout << "Number of fibonacci Numbers in the series are "
   << count_fibonacci(start, last);
   return 0;
}

输出结果

如果我们运行上面的代码,它将生成以下输出-

Number of fibonacci Numbers in the series are 6
 类似资料:
  • 主要内容:递归生成斐波那契数列,总结公元 1202 年,意大利数学家莱昂纳多·斐波那契提出了具备以下特征的数列: 前两个数的值分别为 0 、1 或者 1、1; 从第 3 个数字开始,它的值是前两个数字的和; 为了纪念他,人们将满足以上两个特征的数列称为斐波那契数列。 如下就是一个斐波那契数列: 1 1 2 3 5 8 13 21 34...... 下面的动画展示了斐波那契数列的生成过程: 图 1 斐波那契数列 很多编程题目要求我们输

  • 本文向大家介绍JavaScript中的斐波那契数列,包括了JavaScript中的斐波那契数列的使用技巧和注意事项,需要的朋友参考一下 斐波那契数是这样的数,使得该序列中前两个后的每个数字都是前两个的和。该系列从1、1开始。示例- 我们可以编写一个程序来生成nth,如下所示: 您可以使用以下方式进行测试: 这将给出输出- 让我们看看这些函数调用实际上是如何发生的- 当我们调用f(5)时,我们将调用

  • 题目链接 NowCoder 题目描述 求斐波那契数列的第 n 项,n <= 39。 <!--1}\end{array}\right." class="mathjax-pic"/> --> 解题思路 如果使用递归求解,会重复计算一些子问题。例如,计算 f(4) 需要计算 f(3) 和 f(2),计算 f(3) 需要计算 f(2) 和 f(1),可以看到 f(2) 被重复计算了。 递归是将一个问题划分

  • Python3 实例 斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13,特别指出:第0项是0,第1项是第一个1。从第三项开始,每一项都等于前两项之和。 Python 实现斐波那契数列代码如下: 实例(Python 3.0+)# -*- coding: UTF-8 -*- # Filename : test.py # author by : www.runoob.com

  • 我有一个使用递归打印斐波那契级数的程序。有更好的方法,但我被要求使用递归,所以我不得不这样做。 这是程序: 我知道这对于斐波那契级数来说真的是一种糟糕的方法,从上面可以清楚地看出,当项超过35时,程序需要很多时间才能完成。 我看了这个答案,不明白他们是怎么解决的,但看起来 fibo(int n)的时间复杂度为O(2^n) 我可能完全错了,但我只想: 这个完整程序的时间复杂度是多少,简要解释一下您是