博客
关于我
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/

    你可能感兴趣的文章
    Numpy多项式.Polynomial.fit()给出的系数与多项式.Polyfit()不同
    查看>>
    Numpy如何使用np.umprod重写range函数中i的python
    查看>>
    numpy学习笔记3-array切片
    查看>>
    numpy数组替换其中的值(如1替换为255)
    查看>>
    numpy数组索引-ChatGPT4o作答
    查看>>
    NUMPY矢量化np.prod不能构造具有超过32个操作数的ufunc
    查看>>
    Numpy矩阵与通用函数
    查看>>
    numpy绘制热力图
    查看>>
    numpy转PIL 报错TypeError: Cannot handle this data type
    查看>>
    Numpy闯关100题,我闯了95关,你呢?
    查看>>
    nump模块
    查看>>
    Nutch + solr 这个配合不错哦
    查看>>
    NuttX 构建系统
    查看>>
    NutUI:京东风格的轻量级 Vue 组件库
    查看>>
    NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
    查看>>
    NutzWk 5.1.5 发布,Java 微服务分布式开发框架
    查看>>
    NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
    查看>>
    Nuxt Time 使用指南
    查看>>
    NuxtJS 接口转发详解:Nitro 的用法与注意事项
    查看>>
    NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
    查看>>