2013 - ECJTU 暑期训练赛第六场-problem-F

2024-05-11 03:48

本文主要是介绍2013 - ECJTU 暑期训练赛第六场-problem-F,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

F -F
Crawling in process... Crawling failed Time Limit:1000MS    Memory Limit:32768KB     64bit IO Format:%I64d & %I64u
SubmitStatus Practice HDU 1575

Description

A为一个方阵,则Tr A表示A的迹(就是主对角线上各项的和),现要求Tr(A^k)%9973。
 

Input

数据的第一行是一个T,表示有T组数据。
每组数据的第一行有n(2 <= n <= 10)和k(2 <= k < 10^9)两个数据。
接下来有n行,每行有n个数据,每个数据的范围是[0,9],表示方阵A的内容。
 

Output

对应每组数据,输出Tr(A^k)%9973。
 

Sample Input

     
2 2 2 1 0 0 1 3 99999999 1 2 3 4 5 6 7 8 9
 

Sample Output

     
2 2686
矩阵快速幂
AC代码+解释:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
const int MAX=101;
int n;
using namespace std;
typedef struct Matrix
{int mat[MAX][MAX];//定义矩阵
}matrix;
matrix A,B;
Matrix matrix_mul(matrix a,matrix b)//矩阵乘法
{matrix c;memset(c.mat,0,sizeof(c.mat));int i,j,k;for(i=1;i<=n;i++){for(j=1;j<=n;j++){for(k=1;k<=n;k++){c.mat[i][j]+=a.mat[i][k]*b.mat[k][j];c.mat[i][j]%=9973;//每次加完要对9973取模}}}return c;
}
Matrix matrix_quick_power(matrix a,int k)//重点:矩阵快速幂
{int i;matrix b;memset(b.mat,0,sizeof(b.mat));//初始化for(i=1;i<=n;i++)//这里把b化为单位矩阵,这样如果是第一次乘的话就不会改变a的值b.mat[i][i]=1;while(k)//当k即幂的大小为0时退出循环{if(k&1)//当K为奇数,这里用二进制的“与符号”:&,等同于k%2!=0{b=matrix_mul(a,b);//如果是第一次就乘上单位矩阵不变,不是的话就成上幂的因子数k-=1;}else{a=matrix_mul(a,a);//幂的因子数k>>=1;}}return b;//因为最终k变为0时的前一次k一定为1所以返回b而不是a
}
int main()
{int i,j,sum,k,t;cin>>t;while(t--){cin>>n>>k;for(i=1;i<=n;i++){for(j=1;j<=n;j++){cin>>A.mat[i][j];A.mat[i][j]%=9973;//这里也要取模不然矩阵相乘时会溢出}}B=matrix_quick_power(A,k);sum=0;for(i=1;i<=n;i++){sum+=B.mat[i][i];sum%=9973;//同理取模}cout<<sum<<endl;}return 0;
}


这篇关于2013 - ECJTU 暑期训练赛第六场-problem-F的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/978418

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

uva 10025 The ? 1 ? 2 ? ... ? n = k problem(数学)

题意是    ?  1  ?  2  ?  ...  ?  n = k 式子中给k,? 处可以填 + 也可以填 - ,问最小满足条件的n。 e.g k = 12  - 1 + 2 + 3 + 4 + 5 + 6 - 7 = 12 with n = 7。 先给证明,令 S(n) = 1 + 2 + 3 + 4 + 5 + .... + n 暴搜n,搜出当 S(n) >=

暑期学习总结

iOS学习 前言无限轮播图换头像网络请求按钮的configuration属性总结 前言 经过暑期培训,完成了五个项目的仿写,在项目中将零散的内容经过实践学习,有了不少收获,因此来总结一下比较重要的内容。 无限轮播图 这是写项目的第一个难点,在很多项目中都有使用,越写越熟练。 原理为制造两个假页,在首和尾分别制作最后一页和第一页的假页,当移动到假页时,使用取消动画的方式跳到

rtmp流媒体编程相关整理2013(crtmpserver,rtmpdump,x264,faac)

转自:http://blog.163.com/zhujiatc@126/blog/static/1834638201392335213119/ 相关资料在线版(不定时更新,其实也不会很多,也许一两个月也不会改) http://www.zhujiatc.esy.es/crtmpserver/index.htm 去年在这进行rtmp相关整理,其实内容早有了,只是整理一下看着方

11991 - Easy Problem from Rujia Liu?

题意: 输入一串整型数列,再输入两个数k,v,输出第k个v的序号。不存在则输出0,如第一个样例 8 41 3 2 2 4 3 2 11 3 //第1个3,序号为2,输出22 4 //第2个4,不存在,输出03 2 //第3个2,序号为7,输出74 2 思路: struct num {

HDU 1016 Prime Ring Problem (深搜)

OJ题目 : click here ~~ 大概题意:n个数,形成一个环,使得相邻两个数的和为素数。以1开始,按字典序输出序列。 很简单的深搜。 AC_CODE int n;int visit[22];int num[22];int len;bool Is_prime(int x){for(int i = 2;i*i <= x;i++)if(x%i == 0) return

LVM 'Can’t open /dev/sdb1 exclusively. Mounted filesystem?' Problem

在将几块盘做LVM时,遇到一个之前都没遇到过的问题: root@ubuntu:~# pvcreate /dev/sdc1Can't open /dev/sdc1 exclusively. Mounted filesystem? 首先第一反应就是查看这个分区是否已经在使用了,但是没有。 查看硬盘的一些信息: root@ubuntu:~# cat /proc/partitionsmajo

腾讯暑期实习笔经面经-为你准备(独家资料)

2012腾讯暑期实习笔经面经,技术类 内容逐渐补充。 ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- -- 以下一段话来源

【HDU】3861 The King’s Problem 强连通缩点+有向图最小路径覆盖

传送门:【HDU】3861 The King’s Problem 题目分析:首先强连通缩点,因为形成一个环的王国肯定在一条路径中,这样才能保证拆的少。 然后缩点后就是DAG图了,由于题目要求的是最小路径覆盖,那么二分匹配即可。 代码如下: #include <cstdio>#include <cstring>#include <algorithm>#includ

【ZOJ】3362 Beer Problem 最小费用流

传送门:【ZOJ】3362 Beer Problem 题目分析:这道题本来应该很快就AC的,但是!因为我以前犯的一个致命错误导致我这题一天了到现在才调出来!唉。。失策。。貌似给的模板也有这个错误。。。马上就去改。。但是这个错误竟然还能过掉那么多的题。。害我还要一题一题的改回去。。 本题就是赤裸裸的最小费用流。 新建汇点t(源点即1),将所有的n-1个城市和汇点建边,容量为无穷大,