【题解】NowCoder Fibonacci数列

ops/2024/9/23 19:17:14/

题目来源:牛客

题目链接:Fibonacci数列

Fibonacci数列

题目描述:

Fibonacci 数列是这样定义的:
F[0] = 0
F[1] = 1
for each i ≥ 2 : F[i] = F[i-1] + F[i-2]
因此,Fibonacci 数列就形如:0, 1, 1, 2, 3, 5, 8, 13, …,在 Fibonacci 数列中的数我们称为 Fibonacci 数。给你一个 N ,你想让其变为一个 Fibonacci 数,每一步你可以把当前数字 X 变为 X-1 或者 X+1 ,现在给你一个数 N 求最少需要多少步可以变为 Fibonacci 数。

输入描述:

输入为一个正整数 N(1 ≤ N ≤ 1,000,000)

输出描述:

输出一个最小的步数变为 Fibonacci

示例1

输入:12
输出:2

解析

斐波那契数列真是非常经典的题目啊,虽然题目问的不是斐波那契第几个数字的值,但是也是非常简单的。我们只需要找到距离输入的数字最小的斐波那契数字即可。由于斐波那契数字只跟前两个斐波那契额数字相关,所以我们可以 通过3个变量进行滚动来迭代斐波那契数列
在这里插入图片描述
每次通过 “前锋” c 来判断是否找到输入的数字,最终使其落入 b ~ c 之间。

代码实现

#include<iostream>
using namespace std;int main()
{int N;cin >> N;int a = 0;int b = 1;int c = 1;// 找出输入的数字,使其在 b~c 之间while (N > c){a = b;b = c;c = a + b;}// 输出距离最小的cout << min(N - b, c - N);return 0;
}

http://www.ppmy.cn/ops/33604.html

相关文章

关于YOLO8学习(四)模型转换为ncnn

前文 关于YOLO8学习(一)环境搭建,官方检测模型部署到手机 关于YOLO8学习(二)数据集收集,处理 关于YOLO8学习(三)训练自定义的数据集 简介 本文将会讲解: (1)如何通过PyCharm,进行pt模型的转换,最后输出一个适合手机端使用的模型 开发环境 win10、python 3.11…

opencv4.8 系列一键盘响应操作

监听键盘输入事件 int key waitKey(100);按ESC 按键 退出 int key waitKey(100);if (key27) {break;}输入1 灰色图像 std::cout << "your enter key # 1" << std::endl; cvtColor(image,dst,COLOR_BGR2GRAY);输入2 HSV图像 std::cout << &qu…

[QNX] mmap+cache/nocache+memcpy/asm_memcpy速度对比

mmap nocache介绍 以linux系统的nocache介绍&#xff1a; 在Linux系统中&#xff0c;使用mmap映射文件到内存时可以指定不使用缓存。这可以通过在调用mmap时将MAP_NOCACHE标志传递给mmap函数来实现。 MAP_NOCACHE标志告诉内核不要将映射的内存页缓存到文件系统缓存中&#xff…

ffmpeg 转文件为h265

查看 nvidia-smi ---------------------------------------------------------------------------------------- | NVIDIA-SMI 551.61 Driver Version: 551.61 CUDA Version: 12.4 | |-------------------------------------------------------------------------------------…

微信小程序个人开放服务类目表

微信小程序个人开放服务类目表 服务类目类目分类一类目分类二引导描述出行与交通代驾//生活服务家政、丽人、摄影/扩印、婚庆服务、环保回收/废物回收//餐饮点评与推荐、菜谱、餐厅排队//旅游出境WiFi、旅游攻略//商业服务会展服务、律师/ 【律师】类目需上传《律师执业资格证…

文件上传结合springboot

目录 前台页面 后台接口 文件上传总结 前端页面三要素 服务端接收文件 前台页面 <form action"/upload" method"post" enctype"mutipart/form-data"> 姓名<imput type"text" name"username"><br> 年…

对命令模式的理解

目录 一、场景1、文本编辑器并不是一个好的例子&#xff0c;设备控制器才是2、设备控制器的demo 二、不用命令模式1、代码2、问题 三、使用命令模式1、代码2、当需求变化时2.1 新增代码2.2 优点 四、进一步思考1、省略对Command的建模可以吗&#xff1f;2、命令模式的价值 一、…

[C语言]指针进阶详解

指针是C语言的精髓所以内容可能会比较多&#xff0c;需要我们认真学习 目录 1、字符指针 2、指针数组 3、数组指针 3.1数组指针的定义 3.2&数组名vs数组名 3.3数组指针的使用 4、数组传参和指针传参 4.1一维数组传参 4.2二维数组传参 4.3一级指针传参 4.4二级指…