zoukankan      html  css  js  c++  java
  • P3390 【模板】矩阵快速幂

    就是快速幂和矩阵的结合
    link Miku

    #include<cstdio>
    #include<algorithm>
    #include<cstdio>
    #include<cstring>
    #include<iostream>
    using namespace std;
    long long n,k;
    long long ans[101][101];
    long long tem[101][101];
    long long li[101][101];
    long long mod=1000000007; 
    void tim1(){
    	memset(li,0,sizeof(li));
    	for(int i=1;i<=n;++i){
    		for(int j=1;j<=n;++j){
    			for(int k=1;k<=n;++k){
    				li[i][j]=(li[i][j]+(tem[i][k]*ans[k][j])%mod);
    				li[i][j]%=mod;
    			}
    		}
    	}
    	for(int i=1;i<=n;++i){
    		for(int j=1;j<=n;++j){
    			ans[i][j]=li[i][j];
    		}
    	}
    	return ;
    }
    void tim2(){
    	memset(li,0,sizeof(li));
    	for(int i=1;i<=n;++i){
    		for(int j=1;j<=n;++j){
    			for(int k=1;k<=n;++k){
    				li[i][j]=(li[i][j]+(tem[i][k]*tem[k][j])%mod);
    				li[i][j]%=mod;
    			}
    		}
    	}
    	for(int i=1;i<=n;++i){
    		for(int j=1;j<=n;++j){
    			tem[i][j]=li[i][j];
    		}
    	}
    	return ;
    }
    void power() {
    	while(k){
    		if(k&1){
    			tim1();
    		}
    		tim2();
    		k>>=1;
    	}
    	return ;
    }
    int main(){
    	scanf("%lld%lld",&n,&k);
    	for(int i=1;i<=n;++i){
    		for(int j=1;j<=n;++j){
    			scanf("%lld",&ans[i][j]);
    			tem[i][j]=ans[i][j];
    		}
    	}
    	k--;
    	power();
    	for(int i=1;i<=n;++i){
    		for(int j=1;j<=n;++j){
    			cout<<ans[i][j]<<" ";
    		} 
    		cout<<endl;
    	 } 
    	return 0;
    }
    
  • 相关阅读:
    数据库编程总结
    Excel文件操作方式比较
    大数据导入Excel
    导出Excel
    duilib库分析: 消息流程分析
    ucosII移植
    Log Parser Studio 分析 IIS 日志
    google 搜索关键字技巧
    未知的反物质世界的瞎想
    Scratch 简单的小游戏 --- 碰碰球
  • 原文地址:https://www.cnblogs.com/For-Miku/p/13591917.html
Copyright © 2011-2022 走看看