【笔试】算法的暴力美学——牛客 WY22 :Fibonacci数列

一、题目描述

二、算法原理

思路:列出所有的 Fibonacci 数值,依次和输入的值比较

1)使用一个一维数组来存储 Fibonacci 数值,注意:这个数组只能存储 Fibonacci 数值

2)使用 while 循环来计算并存储 Fibonacci 数值,当这个数组的最后一个数字大于 n 时,那么退出循环

3)此时的情况是:数组的最后一个数字大于 n ,倒数最后一个数字小于 n ,那么我们计算的最小的 n 变成 Fibonacci 数字的步数,就是计算这两个数子的差值;

三、代码实现

cpp 复制代码
#include <iostream>
#include <vector>

using namespace std;

int main()
{
    int n = 0;
    std::cin >> n;

    std::vector<int> ret = {0,1};//存储 Fibonacci 数列

    while(ret.back() < n)//结束循环的 Fibonacci 数 大于 n
    {
        ret.push_back(ret[ret.size() - 1] + ret[ret.size() - 2]);
    }

    if(n == ret.back()) std::cout << 0 << std::endl;
    else
    {
        int mini = min(ret.back() - n, n - ret[ ret.size() - 2 ]);//小的 Fiboncci 数 n  大的 Fiboncci 数(ret.back())
        std::cout << mini << std::endl;
    }

    return 0;
}
相关推荐
Tutankaaa13 分钟前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang00732140 分钟前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee3 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99903 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5053 小时前
深入理解主成分分析(PCA)
算法
apollowing3 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F3 小时前
最小堆定时器
数据结构·算法
Lumos_7773 小时前
Linux -- 线程
java·jvm·算法
七颗糖很甜4 小时前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法
科研前沿4 小时前
镜像视界浙江科技有限公司的关键技术突破有哪些?
大数据·人工智能·科技·算法·音视频·空间计算