日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

矩阵快速幂---BestCoder Round#8 1002

發(fā)布時間:2025/4/16 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 矩阵快速幂---BestCoder Round#8 1002 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.


當(dāng)要求遞推數(shù)列的第n項(xiàng)且n很大時,怎么快速求得第n項(xiàng)呢?
可以用矩陣快速冪來加速計(jì)算。
我們可以用矩陣來表示數(shù)列遞推公式
比如fibonacci數(shù)列 可以表示為 [f(n) ? f(n-1)] = [f(n-1) ? ?f(n-2)] [ 1 1 ]

                          ? ? [ 1 0 ]?
設(shè)A = [ 1 1 ]

   ?[ 1 0 ]

[f(n) ? f(n-1)] = [f(n-2) ? f(n-3)]*A*A
[f(n) ? f(n-1)] = [f(2) ? f(1)]*A^(n-2)
矩陣滿足結(jié)合律,所以先計(jì)算A^(n-2),這個可以用一般快速二分冪的思想來計(jì)算。

BestCoder Round#8 1002
當(dāng)n為奇數(shù)時,f(n) = 2 * f(n-1) + 1
當(dāng)n為偶數(shù)時,f(n) = 2 * f(n-1)
將偶數(shù)項(xiàng)獨(dú)立出來形成單獨(dú)的一個數(shù)列 b(2*n) = 2 * b(2*n-1) + 1 = 4 * (2*n-2) + 2
即b(n) = 4 * b(n-1) + 2
當(dāng)n為偶數(shù)時,計(jì)算b(n/2)即可
當(dāng)n為奇數(shù)時,計(jì)算b(n/2) * 2 + 1即可
因?yàn)閚很大,可以用矩陣快速冪來加速
遞推矩陣為 [b(n) ? 2] = [b(n-1] ? 2] * [ 4 0 ]
              ?  ? ? [ 1 1 ]

?

1 #include <stdio.h> 2 #include <string.h> 3 typedef long long LL; 4 struct Matrix 5 { 6 LL matrix[2][2]; 7 }; 8 int n,m; 9 Matrix operator *(const Matrix &lhs, const Matrix &rhs) 10 { 11 Matrix res; 12 memset(res.matrix, 0 ,sizeof(res.matrix)); 13 int i,j,k; 14 for(k=0; k<2; ++k) 15 for(i=0; i<2; ++i) 16 { 17 if(lhs.matrix[i][k] == 0) continue; 18 for(j=0; j<2; ++j) 19 { 20 if(rhs.matrix[k][j] == 0) continue; 21 res.matrix[i][j] = (res.matrix[i][j] + lhs.matrix[i][k] * rhs.matrix[k][j]) % m; 22 } 23 } 24 return res; 25 } 26 Matrix operator ^(Matrix a, int k) 27 { 28 Matrix res; 29 int i,j; 30 for(i=0; i<2; ++i) 31 for(j=0; j<2; ++j) 32 res.matrix[i][j] = (i == j); 33 while(k) 34 { 35 if(k & 1) 36 res = res * a; 37 a = a * a; 38 k>>=1; 39 } 40 return res; 41 } 42 43 int main() 44 { 45 while(scanf("%d%d",&n,&m)!=EOF) 46 { 47 Matrix a; 48 a.matrix[0][0] = 4; 49 a.matrix[0][1] = 0; 50 a.matrix[1][0] = a.matrix[1][1] = 1; 51 int k = n / 2; 52 a = a ^ k; 53 LL ans =(2 * a.matrix[1][0]) % m; 54 if(n & 1 == 1) 55 ans = (ans * 2 + 1) % m; 56 printf("%lld\n",ans); 57 58 59 } 60 return 0; 61 } View Code

?

轉(zhuǎn)載于:https://www.cnblogs.com/justPassBy/p/3979457.html

總結(jié)

以上是生活随笔為你收集整理的矩阵快速幂---BestCoder Round#8 1002的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲二区av | 免费在线观看你懂的 | 欧美熟妇乱码在线一区 | 天天干天天摸 | 在线看片网站 | 精品国产18久久久久久 | 成人免费毛片嘿嘿连载视频 | 97午夜| 无码人妻av免费一区二区三区 | 国模私拍大尺度裸体av | 操操操操操操操操操操 | 无码人妻黑人中文字幕 | 免费福利视频网站 | 国产精品久久久久久久久久免费 | 色涩网站| 一级特黄aaa大片 | 日韩一级av毛片 | 久久精品7 | 三级黄色免费片 | 国产视频xxxx | 毛片视频免费观看 | 国产精品国产精品国产专区不片 | 国产精品久久无码一三区 | 风间由美一区二区三区 | 精品99999| 婷婷亚洲综合 | 久久超碰在线 | 久久精品国产精品亚洲毛片 | 国产视频福利在线 | 亚洲精品国产精品国自产网站 | 精品国产污污免费网站入口 | 欧美日韩综合精品 | 亚洲精品天堂成人片av在线播放 | 中文日韩在线 | 成人国产片女人爽到高潮 | 亚洲av无码久久忘忧草 | 夜夜草天天干 | 欧美综合亚洲图片综合区 | 成人网免费看 | 日韩成人av在线 | 欧美区一区二区 | 伊人狼人综合 | 最近中文字幕在线观看视频 | 人妻熟人中文字幕一区二区 | 强睡邻居人妻中文字幕 | 亚洲精品国产精品国自产网站按摩 | 天天干一干| 人与动物黄色片 | 国产九九九| 中国久久| 香蕉91视频 | 人妻夜夜爽天天爽三区麻豆av网站 | 麻豆婷婷 | 在线视频一区二区三区四区 | 久久国产三级 | 猎艳山村丰满少妇 | 上原亚衣在线观看 | 亚洲一区二区网站 | 国产精品剧情 | 欧美精品一区在线发布 | 国产成人午夜视频 | 国产无码精品在线播放 | 久久久久久久国产精品毛片 | 少妇按摩一区二区三区 | 凹凸国产熟女精品视频 | 99免费视频 | 人人人人干 | 久久成年人视频 | 激情综合网婷婷 | 日本黄色录相 | 九色视频偷拍少妇的秘密 | 成人综合av | 国产精品免费av一区二区三区 | 狠狠综合久久av一区二区 | 欧美69精品久久久久久不卡 | 日本精品在线播放 | 亚洲视频在线一区二区 | 欧美一区视频在线 | 日韩不卡视频一区二区 | 精品无码成人久久久久久免费 | 有码一区二区 | 日日好av | 日本丰满熟妇hd | 国产欧美中文字幕 | 欧美婷婷六月丁香综合色 | 变态另类一区二区 | 亚洲不卡影院 | 欧美日韩精品 | 国产精品天美传媒 | 美女一二区 | 午夜色播| 欧美日韩精品一区二区 | 无码人妻丰满熟妇啪啪 | 亚洲AV成人无码电影在线观看 | 黄色一级大片在线免费看国产一 | 黄色片网站在线 | 色综合久久久 | 欧美一区二区三区视频 | 美女福利视频网 |