博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
递推式计算与矩阵乘法 C++
阅读量:6657 次
发布时间:2019-06-25

本文共 923 字,大约阅读时间需要 3 分钟。

以斐波那契数列为例,计算斐波那契数列的矩阵方法代码如下:

(快速幂、矩阵乘法)《挑战程序设计竞赛第二版》P199

#include
#include
using namespace std;typedef vector
vec;typedef vector
mat;int M = 10000;mat mul(mat &A,mat &B){ mat C(A.size(),vec(B[0].size())); for(int i = 0;i < A.size();i++) for(int k = 0;k < B.size();k++) for(int j = 0;j < B[0].size();j++) C[i][j] = (C[i][j] + A[i][k]*B[k][j])%M; return C;}mat pow(mat A,int n){ mat res(A.size(),vec(A.size())); for(int i = 0;i < A.size();i++) res[i][i] = 1; while(n > 0){ if(n & 1) res = mul(res,A); A = mul(A,A); n >>= 1; } return res;}void print(mat &A){ for(int i = 0;i < A.size();i++){ for(int j = 0;j < A[0].size();j++) cout << A[i][j] << " "; cout << endl; }} int main(){ mat A(2,vec(2)); A[0][0] = A[0][1] = A[1][0] = 1; A[1][1] = 0; print(A); A = pow(A,100); print(A); return 0;}

 

转载于:https://www.cnblogs.com/long98/p/10352220.html

你可能感兴趣的文章
python时间格式毫秒_Python获取秒级时间戳与毫秒级时间戳
查看>>
getHandel redis_spring-boot-starter-fast-redis
查看>>
springcloud 子项目怎么导入_如何在SpringCloud中使用多个子模块集成Swagger文档,你知道吗?...
查看>>
draggable布局 vue_vue-draggable
查看>>
python要什么电脑配置_学Python需要什么配置的电脑?
查看>>
pythonif条件语句实例_Python基础之条件控制操作实例【if语句】
查看>>
excel操作题_Excel|操作题第4套
查看>>
i5-1135g7相当于什么水平_剑桥英语I优加-剑桥pet相当于国内什么水平
查看>>
mysql8.0150安装教程_MySQL8安装Installer版的图文教程
查看>>
mysql 缓冲区_mysql 系列 缓冲区
查看>>
mysql tablespaces_MySQL8.0-MySQLTablespace
查看>>
mysql enum创建_mysql – 如何在SQLite中创建ENUM类型?
查看>>
mysql5.5.7无法创建.pid_MySQL启动创建不了pid怎么办
查看>>
马哥数据库mysql笔记_马哥学习笔记五MYSQL初步
查看>>
通信原理知识点总结_通信原理课程总结(一)
查看>>
mysql中想选出最新的日期_mysql – 从特定日期开始选择最新版本
查看>>
mysql 二进制日志恢复_使用mysql二进制日志恢复数据
查看>>
mysql 统计信息收集_Oracle 收集统计值 收集统计信息
查看>>
MySQL安装显示路径冲突_linux下的mysql安装路径冲突怎么办
查看>>
django mysql增删查_使用django连接数据库 对数据库 增删改查
查看>>