热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

式子_矩阵快速幂EOJEOJMonthly2021.9SponsoredbyTuSimpleA.AmazingDiscovery

篇首语:本文由编程笔记#小编为大家整理,主要介绍了矩阵快速幂EOJEOJMonthly2021.9SponsoredbyTuSimpleA.AmazingDiscovery相关

篇首语:本文由编程笔记#小编为大家整理,主要介绍了矩阵快速幂EOJ EOJ Monthly 2021.9 Sponsored by TuSimple A. Amazing Discovery相关的知识,希望对你有一定的参考价值。



Problem A: Amazing Discovery

评测传送门
蒟蒻赛时就开了这么一个题,推了好久也还是推不出来😣
看了人家官方题解后,顺利AC。但是,这个推导过程有点搞怪啊,不是看了题解,我还真推不出来这个递推关系。

官方题解:
题解传送门

下面我提供一些推导过程中的式子,可自行代入验证一波。
这里提供一个可以进行数学计算的超强👉代数计算工具网站






S


1



=


2


a



S_1 =2a


S1=2a







S


2



=


2



a


2



+


2


b



S_2 = 2a^2+2b


S2=2a2+2b







S


3



=


2



a


3



+


6


a


b



S_3 = 2a^3+6ab


S3=2a3+6ab







S


4



=


2



a


4



+


2



b


2



+


12



a


2



b



S_4 = 2a^4+2b^2+12a^2b


S4=2a4+2b2+12a2b







S


5



=


2



a


5



+


10


a



b


2



+


20



a


3



b



S_5 = 2a^5+10ab^2+20a^3b


S5=2a5+10ab2+20a3b







S


5



=


2


a






S


4






(



a


2






b


)



S


3




S_5 = 2a * S_4 - (a^2-b)S_3


S5=2aS4(a2b)S3

矩阵快速幂中A矩阵的构造:





[



S


n



,



S



n


+


1




]



[S_n,S_n+1]


[Sn,Sn+1]
×




A



A


A
=




[



S



n


+


1




,



S



n


+


2




]



[S_n+1,S_n+2]


[Sn+1,Sn+2]






A


=







[






0







b






a


2










1







2


a







]








A= \\begingathered \\beginbmatrix 0 & b-a^2 \\\\ 1 & 2a \\endbmatrix \\endgathered


A=[01ba22a]

初始矩阵为:




F


0


=


[


2


,


2


a


]



F0 = [2,2a]


F0=[2,2a]

之后直接矩阵快速幂计算即可。
AcCoding:

#include
#include
#include <iostream>
#include
using namespace std;
typedef long long ll;
const int mod &#61; 998244353;
const int N &#61; 2;
/*
2a * S[n-1] - S[n] &#61; (a - b * b) * S[n - 2]
f0[2] &#61; S[n],S[n&#43;1]
A &#61;
0,2a,
1,b * b - a
*/

void mul(ll c[][N], ll a[][N], ll b[][N])
static ll tmp[N][N];
memset(tmp, 0, sizeof tmp);
for (int i &#61; 0;i < N;i&#43;&#43;)
for (int j &#61; 0;j < N;j&#43;&#43;)
for (int k &#61; 0;k < N;k&#43;&#43;)
(tmp[i][j] &#43;&#61; a[i][k] % mod * b[k][j] % mod) %&#61; mod;



memcpy(c, tmp, sizeof tmp);

int main()
ll a, b, n; scanf("%lld%lld%lld", &a, &b, &n);
ll f[N][N] &#61; 2 * a, 2ll * a * a &#43; 2ll* b ;//n &#61; 1
ll A[N][N] &#61;
0,((b - a * a) % mod &#43; mod) % mod,
1,2ll * a % mod
;
n--;
while (n)
if (n & 1) mul(f, f, A);
mul(A, A, A);
n >>&#61; 1;

ll res &#61; (f[0][0] % mod &#43; mod) % mod;
printf("%lld", res);
return 0;


推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
author-avatar
雨里漾_968
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有