• 快速幂和矩阵快速幂(待进一步补充)


    快速幂

    如计算 a^b^ ,代码如下:

    快速幂代码

    快速幂取模:

    int multi(int a,int b, int mod)
    {
        int ans = 1,base = a;
        while(b!=0)
        {
            if(b&1)
                ans = ans * base % mod;
            base = base * base % mod;
            b>>=1;
        }
        return ans % mod;        //最后不要忘记还要取模
    }
    

    快速幂:

    int multi(int a,int b, int mod)
    {
        int ans = 1,base = a;
        while(b!=0)
        {
            if(b&1)
                ans = ans * base ;
            base = base * base;
            b>>=1;
        }
        return ans;      
    }
    

    矩阵快速幂

    它可以快速求出斐波那契数列,这里以一个题为例,Fibonacci POJ - 3070

    AC代码如下:

    #include <cstdio>
    #include <cstring>
    #include <algorithm>
    #include <cmath>
    using namespace std;
     
    const int MOD = 10000;
     
    struct matrix {		//矩阵 
    	int m[2][2];
    }ans;
     
    matrix base = {1, 1, 1, 0}; 
     
    matrix multi(matrix a, matrix b) {	//矩阵相乘,返回一个矩阵 
    	matrix tmp;
    	for(int i = 0; i < 2; i++) {
    		for(int j = 0; j < 2; j++) {
    			tmp.m[i][j] = 0;
    			for(int k = 0;  k < 2; k++)
    				tmp.m[i][j] = (tmp.m[i][j] + a.m[i][k] * b.m[k][j]) % MOD;
    		}
    	}
    	return tmp;
    }
     
    int matrix_pow(matrix a, int n) {	//矩阵快速幂,矩阵a的n次幂 
    	ans.m[0][0] = ans.m[1][1] = 1;	//初始化为单位矩阵 
    	ans.m[0][1] = ans.m[1][0] = 0;
    	while(n) {
    		if(n & 1) ans = multi(ans, a);
    		a = multi(a, a);
    		n >>= 1;
    	}
    	return ans.m[0][1];
    }
     
    int main() {
    	int n;
        // freopen("in.txt", "r", stdin);
        // freopen("out.txt", "w", stdout);
    	while(scanf("%d", &n), n != -1) {
    		printf("%d
    ", matrix_pow(base, n));
    	}
    	return 0;
    } 
    

    参考博客:https://blog.csdn.net/alps1992/article/details/42131581
    https://blog.csdn.net/u014355480/article/details/44659245

  • 相关阅读:
    结对编程
    四则运算
    认清自我,创造未来!!!
    浅谈GIT
    典型用户及用例故事
    结对编程 四则运算
    四则运算
    《未来的程序员》
    java项目命名规范
    四则运算测试
  • 原文地址:https://www.cnblogs.com/KeepZ/p/11355371.html
Copyright © 2020-2023  润新知