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;
}

相关推荐
斯内科9 小时前
四胞胎素数:找出‌个位数分别是 1、3、7、9‌,且‌十位及更高位数字完全相同‌的质数,例如 11、13、17、19
算法·质数·素数·四胞胎素数
海盗123410 小时前
C#在Distinct()中使用IEqualityComparer<T>
开发语言·c#
Vertira10 小时前
python 配置PostgreSQL 数据库
开发语言·python
Hello.Reader10 小时前
算法基础(十二)——主方法:快速求解常见递归式
算法
想唱rap10 小时前
传输层协议TCP
linux·运维·服务器·网络·c++·tcp/ip
小O的算法实验室10 小时前
2026年IEEE TITS,面向按需外卖配送调度的特定问题知识与基于学习元启发式算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
加勒比海带6610 小时前
目标检测算法——农林行业数据集汇总附下载链接【Plant】
大数据·图像处理·人工智能·算法·目标检测
洛水水10 小时前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
Highcharts.js10 小时前
Highcharts 纯 JavaScript 图表库深度使用评测
开发语言·前端·javascript·功能测试·ecmascript·highcharts·技术评测
瑶池酒剑仙10 小时前
C++类和对象完全指南:从封装继承多态到内存布局的面向对象宝典(雨夜论道)
c语言·开发语言·c++·visual studio