Tr A HDU 1575 (矩阵快速幂)
#include<iostream>
#include<vector>
#include<string>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<list> using namespace std; #define maxn 15
int n, k;
struct matrix//定义一个结构体,方便传递值
{
int m[maxn][maxn];
}; /*
maxn和mod由全局定义,其中mod根据需要可以省去
*/ matrix mul(matrix a, matrix b) //矩阵求积, 矩阵乘法
{
matrix ans;
for(int i = ; i <= n; i++)
{
for(int j = ; j <= n; j++)
{
ans.m[i][j] = ;
for(int k = ; k <= n; k++)
{
ans.m[i][j] += (a.m[i][k] * b.m[k][j]) % ;
ans.m[i][j] %= ;
}
}
}
return ans;
} matrix quick_pow(matrix a, int b) //矩阵快速幂
{
matrix ans;
for(int i = ; i <= n; i++)
{
for(int j = ; j <= n; j++)
{
if(i == j)
ans.m[i][j] = ;
else
ans.m[i][j] = ;//这里要初始化为单位矩阵,类比普通快速幂这里初始化为1
}
}
while(b != )//方法与普通快速幂相同,只有乘法的实现不同
{
if(b % == )
ans = mul(a, ans);
a = mul(a, a);
b /= ;
} return ans;
} int main()
{
int T;
cin >> T;
while(T--)
{
matrix a; cin >> n >> k;
for(int i = ; i<= n; ++i)
for(int j = ; j <= n; ++j)
cin >> a.m[i][j]; matrix tmp = quick_pow(a, k);
int ans = ;
for(int i = ; i<= n; ++i)
ans += tmp.m[i][i] % ; ans %= ; // 最后这里一定要再次取余!
cout << ans << endl;
} return ;
}
Tr A HDU 1575 (矩阵快速幂)的更多相关文章
- HDU - 1575——矩阵快速幂问题
HDU - 1575 题目: A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的和),现要求Tr(A^k)%9973. Input数据的第一行是一个T,表示有T组数据. 每组数据的第一行有n( ...
- hdu 1575(矩阵快速幂)
Tr A Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- HDU 1575 矩阵快速幂裸题
题意:中文题 我就不说了吧,... 思路:矩阵快速幂 // by SiriusRen #include <cstdio> #include <cstring> using na ...
- hdu 1575 矩阵快速幂模板
#include "iostream" #include "vector" #include "cstring" using namespa ...
- HDU 1575 Tr A( 简单矩阵快速幂 )
链接:传送门 思路:简单矩阵快速幂,算完 A^k 后再求一遍主对角线上的和取个模 /********************************************************** ...
- HDU 2855 (矩阵快速幂)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2855 题目大意:求$S(n)=\sum_{k=0}^{n}C_{n}^{k}Fibonacci(k)$ ...
- HDU 4471 矩阵快速幂 Homework
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4471 解题思路,矩阵快速幂····特殊点特殊处理····· 令h为计算某个数最多须知前h个数,于是写 ...
- hdu 1757 (矩阵快速幂) 一个简单的问题 一个简单的开始
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1757 题意不难理解,当x小于10的时候,数列f(x)=x,当x大于等于10的时候f(x) = a0 * ...
- 随手练——HDU 5015 矩阵快速幂
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5015 看到这个限时,我就知道这题不简单~~矩阵快速幂,找递推关系 我们假设第一列为: 23 a1 a2 ...
随机推荐
- js闭包与java内部类
在js中闭包用的比较广泛,主要解决变量作用域导致的问题.
- 使用pageHelper分页查询,报sql语句错误
1.异常详情: 2.异常分析: (1)pageHelper分页大致流程: 配置默认的拦截器:pagehelper.PageInterceptor,对发送的查询语句进行拦截,拦截之后对原有的查询语句进 ...
- Win10弹出需要管理员权限才能删除文件夹,解决办法
Win键+R(就是开始-运行),弹出的输入框输入gpedit.msc回车. 绿色圈内是正解,设置为已禁用.已禁用.已禁用.记着重启才生效.
- c语言学习笔记 - 文件操作
#include <stdio.h>#include <time.h> int main(void){ time_t t; //类似于size_t那 ...
- iPhone开发关于UDID和UUID的一些理解
一.UDID(Unique Device Identifier) UDID是Unique Device Identifier的缩写,中文意思是设备唯一标识. 在很多需要限制一台设备一个账号的应用中 ...
- 83 落单的数 II
原题网址:http://www.lintcode.com/zh-cn/problem/single-number-ii/ 给出3*n + 1 个的数字,除其中一个数字之外其他每个数字均出现三次,找到这 ...
- centos7 安装 python3
sudo yum -y groupinstall "Development tools" sudo yum -y install zlib-devel bzip2-devel op ...
- 移动端开发框架Zepto.js
一.概述 Zepto.js是一个轻量的js库,它与jQuery有类似的API. zepto的设计目的是不到10K的通用库,快速下载,有一个熟悉的api-->精力专注在开发上. 流行起来的原因:轻 ...
- 虚拟机vm安装黑群晖6.2
操作系统选择
- python学习笔记3.2_数据导出
一.data.to_csv:数据导出 1.to_csv:将数据导出为逗号分隔的文件 2.输出为其他分隔符的文件 写入到控制台,并打印:sys.stdout na_rep:对空值进行标注 二.serie ...