【九度OJ】题目1474:矩阵幂 解题报告
【九度OJ】题目1474:矩阵幂 解题报告
标签(空格分隔): 九度OJ
http://ac.jobdu.com/problem.php?pid=1474
题目描述:
给定一个n*n的矩阵,求该矩阵的k次幂,即P^k。
输入:
输入包含多组测试数据。
数据的第一行为一个整数T(0<T<=10),表示要求矩阵的个数。
接下来有T组测试数据,每组数据格式如下:
第一行:两个整数n(2<=n<=10)、k(1<=k<=5),
两个数字之间用一个空格隔开,含义如上所示。
接下来有n行,每行n个正整数,
其中,第i行第j个整数表示矩阵中第i行第j列的矩阵元素Pij且(0<=Pij<=10)。
另外,数据保证最后结果不会超过10^8。
输出:
对于每组测试数据,输出其结果。格式为:
n行n列个整数,每行数之间用空格隔开,注意,每行最后一个数后面不应该有多余的空格。
样例输入:
3
2 2
9 8
9 3
3 3
4 8 4
9 3 0
3 5 7
5 2
4 0 3 0 1
0 0 5 8 5
8 9 8 5 3
9 6 1 7 8
7 2 5 7 3
样例输出:
153 96
108 81
1216 1248 708
1089 927 504
1161 1151 739
47 29 41 22 16
147 103 73 116 94
162 108 153 168 126
163 67 112 158 122
152 93 93 111 97
Ways
数组的k次幂,确实是很难的题目,但是凭借自己能力搞定了,感觉很不容易。
思路很简单,三重循环,前两重循环遍历矩阵的每行每列的位置,第三个循环遍历的是当前相乘的数。因为矩阵乘法每个位置都是n个因子相乘的结果,所以第三重循环也是n个。在纸上笔画一下就知道为什么是三重循环而不是更高。值得一提的是,矩阵乘法的计算的当前位置也已经帮助定了个二维数组的位置。
另外,计算中需要三个数组。array数组保存输入信息,不变化。answer数组保存的是每次求幂的结果,只有在每次求幂结束周才给赋值。midArray是暂存求幂结果,如果没有这个数组,而把每个位置的计算结果放到answer里,那么会影响下一个位置的运算。
#include<stdio.h>
#include <cstring>
using namespace std;
int main() {
int T;
while (scanf("%d", &T) != EOF) {
while (T--) {
int n, k;
scanf("%d%d", &n, &k);
int array[n][n];
int answer[n][n];
int midArray[n][n];
memset(array, 0, sizeof(array));
memset(answer, 0, sizeof(answer));
memset(midArray, 0, sizeof(midArray));
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
int temp;
scanf("%d", &temp);
array[i][j] = temp;
answer[i][j] = temp;
}
}
k--;//循环次数
while (k--) {
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
int temp = 0;
for (int l = 0; l < n; l++) {
temp += answer[i][l] * array[l][j];//忘了+号
}
midArray[i][j] = temp;
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
answer[i][j] = midArray[i][j];
}
}
}
for (int i = 0; i < n; i++) {
bool isFirst = true;
for (int j = 0; j < n; j++) {
if (isFirst) {
printf("%d", answer[i][j]);
isFirst = false;
} else {
printf(" %d", answer[i][j]);
}
}
printf("\n");
}
}
}
return 0;
}
Date
2017 年 3 月 17 日
【九度OJ】题目1474:矩阵幂 解题报告的更多相关文章
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
- 九度oj 题目1007:奥运排序问题
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ题目1105:字符串的反码
tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...
- 九度oj题目1009:二叉搜索树
题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...
- 九度oj题目1002:Grading
//不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...
- 九度OJ题目1003:A+B
while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...
随机推荐
- perl中tr的用法(转载)
转载:http://blog.sina.com.cn/s/blog_4a0824490101hncz.html (1)/c表示把匹配不上的字符进行替换. $temp="AAAABCDEF&q ...
- Visual Studio Code常用操作整理
Live Server插件可以在保存html文件后实时地刷新页面 在html文件中键入"! +Tap"会生成一个html模板 保存文件:Ctrl+S 文件跳转:Ctrl+P 文件内 ...
- JSP内置对象之out对象
一. JSP内置对象的概述 由于JSP使用java作为脚本语言,所以JSP将具有强大的对象处理能力,并且可以动态地创建Web页面内容.但Java语法在使用一个对象前,需要先实例化这 ...
- Maven 目录结构[转载]
转载至:http://www.cnblogs.com/haippy/archive/2012/07/05/2577233.html Maven 标准目录结构 好的目录结构可以使开发人员更容易理解项目, ...
- winXP 下安装python3.3.2
1. 安装python-3.3.2 2. 安装setuptools 下载解压后,进入路径 python setup.py install 3.安装pip 下载解压后,进入路径 python setup ...
- Default arguments and virtual function
Predict the output of following C++ program. 1 #include <iostream> 2 using namespace std; 3 4 ...
- mybatis-扩展
分页插件 使用pageHelper参考官方https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse. ...
- 使用NSURLSessionDataTask实现大文件离线断点下载(完整)
6.1 涉及知识点(1)关于NSOutputStream的使用 //1. 创建一个输入流,数据追加到文件的屁股上 //把数据写入到指定的文件地址,如果当前文件不存在,则会自动创建 NSOutputSt ...
- 【Linux】【Services】【Package】yum
Linux程序包管理(2) CentOS: yum, dnf URL: ftp://172.16.0.1/pub/ YUM: yellow dog, Yellow ...
- Mycat的事务异常:Caused by: java.sql.SQLException: Transaction error, need to rollback.Distributed transaction is disabled!
工作中踩到的一个坑 ,一个报错,导致整个服务不能用.工程部署四个节点,请求是按轮询机制分发的,所以请求四次报错,整个系统瘫痪.记录下 . 项目环境:spring +Mybaties +mycat +D ...