题解 | 矩阵幂

矩阵幂

https://www.nowcoder.com/practice/31e539ab08f949a8bece2a7503e9319a

#include <iostream>
#include<cstring>
#include<string>
using namespace std;

const int N = 12;
int n;
int mode[N][N], res[N][N];
//这里拷贝不能用a,因为这里a是参数
void multiply(int a[][N], int b[][N]) {
    int c[N][N];
    memcpy(c, a, sizeof c);
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n; j++) {
            a[i][j] = 0;
            for (int k = 0; k < n; k++)
                a[i][j] += c[i][k] * b[k][j];
        }

}
int main() {
    int k;
    while (cin >> n >> k) { // 注意 while 处理多个 case
        for (int i = 0; i < n; i++)
            for (int j = 0; j < n; j++)
                cin >> mode[i][j], res[i][j] = mode[i][j];
        for (int i = 0; i < k-1; i++) {
            multiply(res, mode);
        }
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < n; j++) {
                cout << res[i][j];
                if (j != n - 1)cout << ' ';
            }
            cout << endl;
        }

    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

05-23 20:31
已编辑
武汉大学 Java
内向的柠檬精在研究求...:注意把武大标粗标大 本地你俩不是乱杀
实习进度记录
点赞 评论 收藏
分享
门口唉提是地铁杀:之前b站被一个游戏demo深深的吸引了。看up主页发现是个初创公司,而且还在招人,也是一天60。二面的时候要我做一个登录验证和传输文件两个微服务,做完要我推到github仓库,还要我加上jaeger和一堆运维工具做性能测试并且面试的时候投屏演示。我傻乎乎的做完以后人家跟我说一句现在暂时不招人,1分钱没拿到全是白干
你的秋招第一场笔试是哪家
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务