博客
关于我
hdu 1757 A Simple Math Problem(矩阵快速幂)
阅读量:136 次
发布时间:2019-02-27

本文共 2121 字,大约阅读时间需要 7 分钟。

?????????????

?????????????????????????????????????????????????????????????

1. ???????

???????????????????????????????????????? $A$ ? $n$ ??????? $A^n = A \cdot A \cdot \ldots \cdot A$?? $n$ ? $A$??????????? $O(n)$ ??????????????????????????????????????? $O(\log n)$??????????

2. ????

???????????

#include 
using namespace std;#define mod(x) ((x) % m)int k, m;struct mat { int d[10][10]; mat operator*(const mat x) { mat ret; int tmp; for (int i = 0; i < 10; i++) { for (int j = 0; j < 10; j++) { tmp = 0; for (int k = 0; k < 10; k++) { tmp = mod(tmp + d[i][k] * x.d[k][j]); } ret.d[i][j] = tmp; } } return ret; } void init_unit() { for (int i = 0; i < 10; i++) for (int j = 0; j < 10; j++) d[i][j] = (i == j) ? 1 : 0; } void init() { for (int i = 0; i < 10; i++) for (int j = 0; j < 10; j++) d[i][j] = (i == j + 1) ? 1 : 0; } void set(int i, int v) { d[9 - i][9] = v; }};mat fastPow(mat base, int pow) { mat res; res.init_unit(); while (pow) { if (pow & 1) res = res * base; base = base * base; pow >>= 1; } return res;}int main() { int tmp; while (scanf("%d%d", &k, &m) == 2) { if (k < 10) { printf("%d\n", k % m); continue; } a.init(); for (int i = 0; i < 10; i++) scanf("%d", &tmp), a.set(i, tmp); a = fastPow(a, k - 9); int ans = 0; for (int i = 0; i < 10; i++) ans = mod(ans + a.d[i][9] * i); printf("%d\n", ans); } return 0;}

3. ????

  • ?????????

    ??? mat ????? 10x10 ?????????????????????????????????????

  • ?????

    • init_unit() ????????????? 1???? 0??
    • init() ????????????????????? 1???? 0?
    • set() ????????????????
  • ?????

    fastPow ???????????????????????????????????????????????????

  • ?????

    ?????? k ? m?????? a????????????? a ???????????????

  • 4. ??

    ???????????????????????????????????????????????????????????????????????????

    转载地址:http://dwib.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现乘方运算---m的n次方(附完整源码)
    查看>>
    Objective-C实现二叉树遍历算法(附完整源码)
    查看>>
    Objective-C实现二进制补码算法(附完整源码)
    查看>>
    Objective-C实现互斥锁同步执行两个线程函数(附完整源码)
    查看>>
    Objective-C实现交易密码算法(附完整源码)
    查看>>
    Objective-C实现低通滤波器(附完整源码)
    查看>>
    Objective-C实现使用管道重定向进程输入输出(附完整源码)
    查看>>
    Objective-C实现关系矩阵A和B的乘积(附完整源码)
    查看>>
    Objective-C实现内存映射文件(附完整源码)
    查看>>
    Objective-C实现内存泄露检查(附完整源码)
    查看>>
    Objective-C实现内格尔·施雷肯伯格算法(附完整源码)
    查看>>
    Objective-C实现分块查找算法(附完整源码)
    查看>>
    Objective-C实现分水岭算法(附完整源码)
    查看>>
    Objective-C实现分解质因数(附完整源码)
    查看>>
    Objective-C实现切换数字的符号switchSign算法(附完整源码)
    查看>>
    Objective-C实现创建多级目录(附完整源码)
    查看>>
    Objective-C实现删除重复的字母字符算法(附完整源码)
    查看>>
    Objective-C实现判断32位的数字是否为正数isPositive算法(附完整源码)
    查看>>
    Objective-C实现十进制转N进制算法(附完整源码)
    查看>>
    Objective-C实现华氏温度转摄氏温度(附完整源码)
    查看>>