C++ B (1124) : 斐波那契数列第n项Plus

文章目录


一、题目描述


二、参考代码

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

using namespace std;

const long long MOD = 1e9 + 7; // 取模的值

// 定义矩阵类
class Matrix {
public:
    vector<vector<long long>> data;

    // 构造函数,创建一个大小为 size x size 的矩阵,初始化为0
    Matrix(int size) : data(size, vector<long long>(size, 0)) {}

    // 矩阵乘法
    Matrix operator*(const Matrix& other) const {
        int size = data.size();
        Matrix result(size);
        for (int i = 0; i < size; ++i) {
            for (int j = 0; j < size; ++j) {
                for (int k = 0; k < size; ++k) {
                    result.data[i][j] += (data[i][k] * other.data[k][j]) % MOD;
                    result.data[i][j] %= MOD; // 取模运算
                }
            }
        }
        return result;
    }
};

// 计算矩阵快速幂
Matrix matrixPower(Matrix base, int n) {
    int size = base.data.size();
    Matrix result(size);
    // 初始化为单位矩阵
    for (int i = 0; i < size; ++i) {
        result.data[i][i] = 1;
    }
    // 循环计算幂
    while (n > 0) {
        if (n & 1) {
            result = result * base;
        }
        base = base * base;
        n >>= 1;
    }
    return result;
}

// 计算斐波那契数列的第 n 项
long long fibonacci(int n) {
    if (n <= 0) return 0;
    if (n == 1) return 1;

    Matrix base(2);
    base.data[0][0] = 1;
    base.data[0][1] = 1;
    base.data[1][0] = 1;
    base.data[1][1] = 0;

    Matrix result = matrixPower(base, n - 1);
    return result.data[0][0] % MOD;
}

int main() {
    int n;
    while (cin >> n)
    {
        long long result = fibonacci(n);
        cout << result << endl;
    }




    return 0;
}

相关推荐
麦兜*4 小时前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3
Coovally AI模型快速验证5 小时前
农田扫描提速37%!基于检测置信度的无人机“智能抽查”路径规划,Coovally一键加速模型落地
深度学习·算法·yolo·计算机视觉·transformer·无人机
mit6.8245 小时前
[openvela] Hello World :从零开始的完整实践与问题复盘
c++·嵌入式硬件
pusue_the_sun5 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
萧鼎5 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python
RaymondZhao345 小时前
【全面推导】策略梯度算法:公式、偏差方差与进化
人工智能·深度学习·算法·机器学习·chatgpt
艾伦~耶格尔6 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
zhangfeng11336 小时前
DBSCAN算法详解和参数优化,基于密度的空间聚类算法,特别擅长处理不规则形状的聚类和噪声数据
算法·机器学习·聚类
yujkss6 小时前
Python脚本每天爬取微博热搜-终版
开发语言·python
yzx9910136 小时前
小程序开发APP
开发语言·人工智能·python·yolo