【笔试】算法的暴力美学——牛客 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;
}
相关推荐
小欣加油16 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly16 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕17 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei18 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld18 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi819 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang21 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby21 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠1 天前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力1 天前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试