斐波那契数列

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO

联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬

学习必须往深处挖,挖的越深,基础越扎实!

阶段1、深入多线程

阶段2、深入多线程设计模式

阶段3、深入juc源码解析

阶段4、深入jdk其余源码解析


阶段5、深入jvm源码解析

码哥源码部分

码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】

码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】

码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】

码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】

码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】

码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】

终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!

打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】

题目描述

大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。

n<=39

首先解释一下斐波那契数列,表达式f(n)=f(n-1)+f(n-2),也就是{0,1,1,2,3......}

这道题目递归的时间复杂度很高,迭代时间复杂度为n,使用通项公式的时间复杂度为1;

在这里很明显第一眼看见首先想到的就是递归,我第一次用了就是递归,但是其时间复杂度贼高,因为它在递归的时候,计算的每个值都是要从f(0)+f(1)....一直加到你收递归的值,这样下去cpu消耗巨大,贴上代码:

    public  int Fibonacci(int n) {if(n==1) {return 1;}if(n==0) {return 0;}return Fibonacci(n-1)+Fibonacci(n-2);}

它的运行时间:

然后我又使用了迭代的方式:

    public  int FibonacciFor(int n) {if(n==1) {return 1;}if(n==0) {return 0;}int[] arr=new int[n+1];arr[0]=0;arr[1]=1;for(int i=2;i<n+1;i++) {arr[i]=arr[i-1]+arr[i-2];}return arr[n];}

它的运行时间:

第三种方式,使用通项公式:

     public  int Fibonacci(int n) {double number=0;double x1=Math.pow((1+Math.sqrt(5))/2, n);double x2=Math.pow((1-Math.sqrt(5))/2, n);number=(x1-x2)/Math.sqrt(5);return (int) number;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/648502.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网闸网络ip端口映射原理分析

今天我们进行网闸网络ip端口映射原理分析&#xff1a;即两个不同网段的网址进行网络通信&#xff0c;需要路由器、网关等配置。举例更形象一些。 一、相同端口映射 1、正向访问 比如两个不同网段的网络ip:A:10.18.3.119 需要和B:10.199.177.10 进行通信&#xff0c;A要访问…

ffmpeg和opencv一些容易影响图片清晰度的操作

ffmpeg 转视频或者图片&#xff0c;不指定码率清晰度会下降 ffmpeg -i xxx.png xxx.mp4 码率也叫比特率&#xff08;Bit rate&#xff09;(也叫数据率)是一个确定整体视频/音频质量的参数&#xff0c;秒为单位处理的字节数&#xff0c;码率和视频质量成正比&#xff0c;在视频…

PyTorch中self.layers的作用

self.layers 是一个用于存储网络层的属性。它是一个 nn.ModuleList 对象&#xff0c;这是PyTorch中用于存储 nn.Module 子模块的特殊列表。 为什么使用 nn.ModuleList&#xff1f; 在PyTorch中&#xff0c;当需要处理多个神经网络层时&#xff0c;通常使用 nn.ModuleList 或 …

TCP三次握手-普通话版

前言&#xff1a;UDP和TCP 总拿UDP和TCP进行比较&#xff0c;为什么呢&#xff1f;因为UDP是不可靠传输&#xff0c;数据过来后把数据分成小份后就发送出去了&#xff0c;我不管你们收没收到哈&#xff0c;反正我是发过去了&#xff0c;你能收到多少就看这网速行不行&#xff0…

IP被封怎么办?访问网站时IP被阻止?解决IP禁令全方法

相信很多人遇到过IP禁令&#xff1a;比如你在访问社交媒体、搜索引擎或电子商务网站时会被限制访问&#xff0c;又或者你的的账号莫名被封&#xff0c;这些由于网络上的种种限制我们经常会遭遇IP被封的情况&#xff0c;导致无法使用继续进行网络行动。在本文中&#xff0c;我们…

linux动态库,静态库

参考 链接 https://blog.csdn.net/Goforyouqp/article/details/132106168 /* ---------- h.h 文件 -------------- */ #ifndef H_H #define H_H void print(void); #endif /* ---------- h.c 文件 -------------- */ #include "h.h" #include &l…

牛客周赛 Round 29(A B C D E)

目录 A.小红大战小紫 题目大意&#xff1a; 解题思路&#xff1a; AC代码&#xff1a; B.小红的白日梦 题目大意&#xff1a; 解题思路&#xff1a; AC代码&#xff1a; C.小红的小小红 题目大意&#xff1a; AC代码&#xff1a; D.小红的中位数 题目大意&#xff…

04 约数

定义&#xff1a; 若整数n除以整数d的余数为0&#xff0c;即d能够整除n&#xff0c;n是d的倍数&#xff0c;记作d|n. 通过质因子求一个数的约数 如果n可以表示成 其中均为n的质因子 因为对于任意一个质因子都有选0个 选1个 选2个....选个共种可能&#xff0c; n的约数个数…

在DevEco开发工具中,使用Previewer预览界面中的UI组件

1、在DevEco工具中&#xff0c;点击并展开PreViewer预览器 2、在PreViewer预览器中&#xff0c;点击Tt按钮&#xff08;Inspector&#xff09;切换至组件查看模式 3、在组件查看模式下选择组件&#xff0c;代码呈现选中状态&#xff0c;右侧呈现组件树&#xff0c;右下方呈现组…

ARM 驱动 1.22

linux内核等待队列wait_queue_head_t 头文件 include <linux/wait.h> 定义并初始化 wait_queue_head_t r_wait; init_waitqueue_head(&cm_dev->r_wait); wait_queue_head_t 表示等待队列头&#xff0c;等待队列wait时&#xff0c;会导致进程或线程被休眠&…

4.调研什么样的框架可以提高ROI

一、回归本源&#xff0c;框架是为了支撑我们测试&#xff0c;所以我们对框架的要求 1.框架满足我们的测试需求 UI框架有对象识别能力API框架有http原语封装&#xff0c;对xml json支持单元测试框架有mock能力 2.框架应有广泛的同行用户、持续更新、成熟的社区和积极的客户响…

qiankun微前端部署(主/子应用部署在同一个服务)

一、部署配置 qiankun微前端改造配置就不记录了&#xff0c;只记录部署需要的配置 mypro&#xff1a;自定义的子应用名称 1. 主应用配置 &#xff08;1&#xff09;.env文件BASE_URL /MicroBase/&#xff08;2&#xff09; vue.config.js文件module.exports {publicPath: …

倍增算法笔记

主要应用场景 RMQ&#xff1a;区间最值问题 LCA&#xff1a;最近公共祖先问题 RMQ问题——区间最值 如果用数组f[N]存储,用数组a[i][j]表示从第i个数起连续 2^j 个数中的最大值,[i,i 2^j - 1],显然a[i][0] f[i],则很容易得到状态转移方程: a[i][j] max(a[i][j - 1], a[i …

读书笔记-《数据结构与算法》-摘要11[Divide and Conquer - 分治法]

在计算机科学中&#xff0c;分治法是一种很重要的算法。分治法即『分而治之』&#xff0c;把一个复杂的问题分成两个或更多的相同或相似的子问题&#xff0c;再把子问题分成更小的子问题……直到最后子问题可以简单的直接求解&#xff0c;原问题的解即子问题的解的合并。这个思…

电商API接口|爬虫案例|采集某东商品评论信息

前言&#xff1a; 平常大家都有网上购物的习惯&#xff0c;在商品下面卖的好的产品基本都会有评论&#xff0c;当然也不排除有刷评论的情况&#xff0c;因为评论会影响我们的购物决策。今天主要分享用pythonre正则表达式获取京东商品评论。API接口获取京东平台商品详情SKU数据…

11k+ star 一款不错的笔记leanote安装教程

特点 支持普通模式 支持markdown模式 支持搜索 安装教程 1.安装mongodb 1.1.下载 #下载 cd /opt wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.1.tgz 1.2解压 tar -xvf mongodb-linux-x86_64-3.0.1.tgz 1.3配置mongodb环境变量 vim /etc/profile 增…

电脑可以连接wifi,甚至可以qq聊天,但就是不能用浏览器上网,一直显示未检测出入户网线的解决方案

今天回到家&#xff0c;准备办公却发现电脑可以连接wifi&#xff0c;甚至可以qq聊天&#xff0c;但就是不能用浏览器上网&#xff0c;一直显示未检测出入户网线的解决方案&#xff0c;小白也可以看懂 以下有几种解决方案&#xff0c;不妨都试试&#xff0c;估计可以解决95%的相…

CANoe使用大全

本专栏为入门级别保姆教程&#xff0c;主要面对CANoe使用的零基础受众。 持续更新中… &#x1f697;【CANoe使用大全】——工程新建 &#x1f697;【CANoe使用大全】——DBC数据库制作 &#x1f697;【CANoe使用大全】——Trace窗口 &#x1f697;【CANoe使用大全】——Gr…

深入理解 MySQL 中的 HAVING 关键字和聚合函数

深入理解 MySQL 中的 HAVING 关键字和聚合函数 在处理数据库查询时&#xff0c;尤其是涉及到大量数据分析和报表生成的场合&#xff0c;了解如何有效使用 SQL 语句中的 HAVING 关键字和聚合函数变得尤为重要。 什么是 HAVING 关键字&#xff1f; HAVING 关键字在 SQL 语句中…

C#-前后端分离连接mysql数据库封装接口

C#是世界上最好的语言 新建项目 如下图所示选择框红的项目 然后新建 文件夹 Common 并新建类文件 名字任意 文件内容如下 因为要连接的是mysql数据库 所以需要安装 MySql.Data.MySqlClient 依赖; using MySql.Data.MySqlClient; using System.Data;namespace WebApplication1.…