zoukankan      html  css  js  c++  java
  • 矩阵递推关系的建立 and 矩阵快速幂

    • [递推关系的建立]

    • [矩阵快速幂模板]
    #include<bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    const int inf = 0x3f3f3f3f;
    const int mod = 1e9+7;
    const int N = 2;
    struct ma{
    	ll a[N][N];
    	void init()// 初始化为单位矩阵 
    	{
    		memset(a,0,sizeof a);
    		for(int i=0;i<N;i++) a[i][i] = 1;
    	}
    };
    ma mul(ma a,ma b)// 矩阵相乘 
    {	
    	ma ans;  
    	for(int i=0; i<N; i++)// N:第一个矩阵的行 
    	{
    		for(int j=0; j<N; j++)// N:第二个矩阵的列 
    		{
    			ll s = 0;
    			for(int k=0; k<N; k++) // N:第二个矩阵的列 
    			{
    				s = ( s + a.a[i][k]*b.a[k][j]%mod )%mod;
    			}
    			ans.a[i][j] = s;
    		}
    	}
    	return ans;
    }
    ma qpow(ma aa,ll bb)// 矩阵快速幂 
    {
    	ma ans;
    	ans.init();
    	while( bb )
    	{
    		if( bb&1 ) ans = mul(ans,aa);
    		aa = mul(aa,aa);
    		bb >>= 1;
    	}
    	return ans;
    } 
    
    int main()
    {
    	int n; 
    	while( cin>>n )
    	{
    		ma a;
    		a.a[0][0] = a.a[0][1] = a.a[1][0] = 1;
    		a.a[1][1] = 0;
    		ma ans = qpow(a,n);
    		cout<<ans.a[0][0]<<" "<<ans.a[0][1]<<"
    ";
    		cout<<ans.a[1][0]<<" "<<ans.a[1][1]<<"
    ";
    	 } 
    	 /*
    		很容易就可以发现当f[1] = f[2] = 1;
    		ans.a[0][0] = f[n+1] 
    		ans.a[0][1] = f[n] 
    	*/
    } 
    
    
  • 相关阅读:
    celery worker的工作模式
    动态加载js
    PHP加密解密
    js加载div, 元素事件不生效问题
    任意页面加载聊天框组件(也可用于其他)
    重装系统
    vue 跨域问题
    859. Buddy Strings
    316. Remove Duplicate Letters
    654. Maximum Binary Tree
  • 原文地址:https://www.cnblogs.com/xiaoxiao179/p/13603783.html
Copyright © 2011-2022 走看看