最近学了矩阵,kzj大佬推荐了我这一道题目

乍一眼看上去,没看出是矩阵,就随便打了一个暴力,30分。

然后仔细分析了一波,发现蛮简单的。

结果全wa了,先看看下面的错误分析吧!

首先,设f[n]为最终答案,易得出$$ f[n]=f[n-1]*10+n$$

然后魔改一下:$$ f[n]=f[n-1]*10+n-1 => $$

\[\begin{matrix}
10&0&0\\
1&1&0\\
1&1&1\\
\end{matrix}\]

信心一波过样例提交,0分。

心态炸了,仔细想了想,原来这个矩阵是会变化的。

假设n的位数为k。

\[f[n]=f[n-1]*10^k+n-1$$ 这才是正确的递推公式。

所以矩阵也要改为:

$$\begin{matrix}
10^k&0&0\\
1&1&0\\
1&1&1\\
\end{matrix}\]

那么,矩阵会成长,怎么做呢,

我们可以分开处理,初始矩阵 \(f[0] => (0,0,1)\)

从1枚举位数,一直到\(length(n)-1\)位,一直乘\(10^k\)的矩阵\(9*10^{k-1}\)次。

最后处理\(length(n)\)位,乘以\(10^{length(n)}\)矩阵\(n-\sum_{k=1}^{length(n)}(9*10^{k-1})\)次。

献上巨弱的丑代码吧~

#include <bits/stdc++.h>
using namespace std;
typedef unsigned long long ull; const int K=0;
ull n,m,len,p,tot;
ull f[]={0,0,0,1},t[4][4];
ull suan(ull,ull);
void fuyan();
void yuzhouzhou();
ull getpow(ull,ull);
string work();
string w=work();
int main() {;;;;;;;;;;;;;;;;;;} ull suan(ull x,ull y)
{
ull d=0;
while (y) {
if (y&1) d=(d%m+x%m)%m;
x=(x%m+x%m)%m,y>>=1;
}
return d%m;
} void fuyan()
{
ull d[4];
memcpy(d,f,sizeof(d));
memset(f,0,sizeof(f));
for (int i=1;i<=3;++i)
for (int j=1;j<=3;++j)
f[i]=(f[i]%m+suan(d[j]%m,t[j][i]%m))%m;
} void yuzhouzhou()
{
ull d[4][4];
memcpy(d,t,sizeof(d));
memset(t,0,sizeof(t));
for (int i=1;i<=3;++i)
for (int j=1;j<=3;++j)
for (int k=1;k<=3;++k)
t[i][j]=(t[i][j]%m+suan(d[i][k]%m,d[k][j]%m))%m;
} ull getpow(ull x,ull y)
{
ull d=x;
for (int i=1;i<y;++i) d*=10;
return d;
} string work()
{
cin>>n>>m;
p=n;
while (p) ++len,p/=10;
for (int i=1;i<len;++i) {
p=getpow(9,i);
tot+=p;
t[1][1]=getpow(10,i);
t[1][2]=t[1][3]=t[2][3]=0;
t[2][1]=t[2][2]=t[3][1]=t[3][2]=t[3][3]=1;
while (p) {
if (p&1) fuyan();
yuzhouzhou(),p>>=1;
}
}
p=n-tot;
t[1][1]=getpow(10,len);
t[1][2]=t[1][3]=t[2][3]=0;
t[2][1]=t[2][2]=t[3][1]=t[3][2]=t[3][3]=1;
while (p) {
if (p&1) fuyan();
yuzhouzhou(),p>>=1;
}
cout<<f[1];
return "You succeeded,boy!";
}

洛谷 P3216 [HNOI2011]数学作业的更多相关文章

  1. 洛谷P3216 [HNOI2011] 数学作业 [矩阵加速,数论]

    题目传送门 数学作业 题目描述 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 N和 M,要求计算 Concatenate (1 .. N)Mod M 的值,其中 C ...

  2. 洛谷P3216 [HNOI2011]数学作业

    题目描述 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 N 和 M,要求计算 Concatenate (1 .. N) Mod M 的值,其中 Concatenat ...

  3. [bzoj2326] [洛谷P3216] [HNOI2011] 数学作业

    想法 最初的想法就是记录当前 \(%m\) 值为cur,到下一个数时 \(cur=cur \times 10^x + i\) n这么大,那就矩阵乘法呗. 矩阵乘法使用的要点就是有一个转移矩阵会不停的用 ...

  4. [luogu P3216] [HNOI2011]数学作业

    [luogu P3216] [HNOI2011]数学作业 题目描述 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 N 和 M,要求计算 Concatenate (1 ...

  5. P3216 [HNOI2011]数学作业 (矩阵快速幂)

    P3216 [HNOI2011]数学作业 题目描述 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 NN 和 MM ,要求计算 Concatenate (1 .. N ...

  6. P3216 [HNOI2011]数学作业

    题目描述 小 C 数学成绩优异,于是老师给小 C 留了一道非常难的数学作业题: 给定正整数 N 和 M ,要求计算Concatenate (1 .. N) Mod M 的值,其中 Concatenat ...

  7. bzoj2326: [HNOI2011]数学作业

    矩阵快速幂,分1-9,10-99...看黄学长的代码理解...然而他直接把答案保存在最后一行(没有说明...好吧应该是我智障这都不知道... #include<cstdio> #inclu ...

  8. BZOJ 2326: [HNOI2011]数学作业( 矩阵快速幂 )

    BZOJ先剧透了是矩阵乘法...这道题显然可以f(x) = f(x-1)*10t+x ,其中t表示x有多少位. 这个递推式可以变成这样的矩阵...(不会用公式编辑器...), 我们把位数相同的一起处理 ...

  9. 洛谷试炼场-简单数学问题-P1403 [AHOI2005]-因数

    洛谷试炼场-简单数学问题 P1403 [AHOI2005]约数研究 Description 科学家们在Samuel星球上的探险得到了丰富的能源储备,这使得空间站中大型计算机"Samuel I ...

随机推荐

  1. 2017.7.1 mysql安装与启动(已验证可以使用)

    下载地址:http://learning.happymmall.com/ 之前一直用解压版安装,启动mysql服务的时候总是失败,这次用mysql installer安装一遍,终于成功启动. 1.下载 ...

  2. Assets 读取assets中的文件

    res/raw和assets的相同点: 1.两者目录下的文件在打包后会原封不动的保存在apk包中,不会被编译成二进制. res/raw和assets的不同点:1.res/raw中的文件会被映射到R.j ...

  3. gitlab创建项目代码:

    cd (当前工程文件夹目录) git init     //初始化git git remote add origin http://worker.njbandou.com/KLElevator/kle ...

  4. vscode - emmet失效?

    把emmet设置覆盖为用户.

  5. react-native 常见操作 及 git 补充

    一. react-native 常见操作 1.创建项目 react-native init Market(项目名称,首字母大写) 2.安装常用插件 npm install react-native-t ...

  6. 基于React的PC网站前端架构分析

    代码地址如下:http://www.demodashi.com/demo/12252.html 本文适合对象 有过一定开发经验的初级前端工程师: 有过完整项目的开发经验,不论大小: 对node有所了解 ...

  7. UVa 437 The Tower of Babylon(DP 最长条件子序列)

     题意  给你n种长方体  每种都有无穷个  当一个长方体的长和宽都小于还有一个时  这个长方体能够放在还有一个上面  要求输出这样累积起来的最大高度 由于每一个长方体都有3种放法  比較不好控制 ...

  8. elk升级文档

    1.kibana等都统一版本了,5.4版本的kibana要5.4版本的elasticsearch 2.现有架构: logstash logstash读取日志-------->内网redis做队列 ...

  9. STM32F4先设置寄存器还是先使能时钟

    http://zhidao.baidu.com/link?url=gdVNuIgLOJcV37QzbCx0IrFip5pskiPQDWpoZayr_xBEe120p4d_iWtrfDl1d4tSFaH ...

  10. JSON-Schema 最科学的表单验证模式

    相关传送门: # JSON schema与表单验证 https://mp.weixin.qq.com/s?__biz=MjM5MTA1MjAxMQ==&mid=2651226711&i ...