洛谷P2233 [HNOI2002]公交车路线 题解 矩阵快速幂

题目链接:https://www.luogu.com.cn/problem/P2233

解题思路:

矩阵快速幂。

思路完全来自 ghj1222大佬的博客

示例代码:

#include <bits/stdc++.h>
using namespace std;
const int MOD = 1000;
struct Matrix {
    int a[8][8];
    Matrix operator * (Matrix b) const {
        Matrix c;
        memset(c.a, 0, sizeof(c.a));
        for (int i = 0; i < 8; i ++)
            for (int j = 0; j < 8; j ++)
                for (int k = 0; k < 8; k ++)
                    c.a[i][j] = (c.a[i][j] + a[i][k] * b.a[k][j]) % MOD;
        return c;
    }
} a, c;
int r[8][8] = {
    0, 1, 0, 0, 0, 0, 0, 1,
    1, 0, 1, 0, 0, 0, 0, 0,
    0, 1, 0, 1, 0, 0, 0, 0,
    0, 0, 1, 0, 1, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0, // E没有出边
    0, 0, 0, 0, 1, 0, 1, 0,
    0, 0, 0, 0, 0, 1, 0, 1,
    1, 0, 0, 0, 0, 0, 1, 0,
};
int n;
int main() {
    cin >> n;
    memset(c.a, 0, sizeof(c.a));
    for (int i = 0; i < 8; i ++) c.a[i][i] = 1;
    memcpy(a.a, r, sizeof(r));
    while (n > 0) {
        if (n % 2) c = c * a;
        a = a * a;
        n /= 2;
    }
    cout << c.a[0][4] << endl;
    return 0;
}
posted @ 2020-11-08 10:36  quanjun  阅读(142)  评论(0编辑  收藏  举报