特征根法求通项+广义Fibonacci数列找循环节 - HDU 5451 Best Solver
Best Solver#
Problem's Link
#
Mean:
给出x和M,求:(5+2√6)^(1+2x)的值。x<2^32,M<=46337.
analyse:
这题需要用到高中的数学知识点:特征根法求递推数列通项公式。
方法是这样的:
对于这题的解法:
记λ1=5+2√6,λ2=5-2√6,则λ1λ2=1,λ1+λ2=10
根据韦达定理可以推导出:λ1,λ2的特征方程为 x^2-10x+1=0
根据λ1=5+2√6,λ2=5-2√6是特征方程x^2-10x+1=0的解,可以求出:b=-10,c=1
再使用该特征方程反向推导出递推公式为:a[n]=10*a[n-1]-a[n-2]
再由特征根法确定通项为:a[n]=(5+2√6)^n+(5-2√6)^n
观察通项,发现(5-2√6)^n<1,(5+2√6)^n>1。并且可以确定(5+2√6)^n的整数部分的值为a[n]-1
到这里,可以利用线性递推公式a[n]=10*a[n-1]-a[n-2],构造矩阵来找循环节。
为什么要找循环节呢?
因为n=2^x相当大,而模数M<=46337,对于每一个模数M,都存在循环节,这样的话我们就不需要完整的计算n次幂运算了。
而且我们发现这些循环节都比较小,所以我们可以直接暴力求矩阵循环节。
Time complexity: O(N+logx)
作者:北岛知寒
出处:https://www.cnblogs.com/crazyacking/p/4826558.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?