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

    你可能感兴趣的文章
    php 接口类与抽象类的实际作用
    查看>>
    PHP 插入排序 -- 折半查找
    查看>>
    PHP 支持8种基本的数据类型
    查看>>
    php 放大镜,放大镜放大图片效果
    查看>>
    PHP 数据库连接池实现
    查看>>
    php 数组 区别,PHP中数组的区别
    查看>>
    PHP 数组怎么添加一个元素
    查看>>
    PHP 文件操作
    查看>>
    php 文字弹幕效果代码,HTML5文字弹幕效果
    查看>>
    php 时间日期函数,获取今天开始时间,结束时间
    查看>>
    php 标准规范
    查看>>
    PHP 浮点型精度运算相关问题
    查看>>
    php 浮点型计算精度问题
    查看>>
    php 特定时间段统计,jpgraph某个时间段的数据统计
    查看>>
    php 生成csv mac下乱码
    查看>>
    php 生成证书 签名及验签
    查看>>
    PHP 的标准输入与输出
    查看>>
    php 笔记 (早前的,很乱)
    查看>>
    PHP 第一天
    查看>>
    Redis使用量暴增,快速定位有哪些大key在作怪
    查看>>