PE440
一些证明,推荐复制入atom观看
首先我们考虑这个T(n)是什么,我们可以列出递归式:
(definition:T)
T(0) = 1
T(1) = 10
T(n) = 10*T(n-1) + T(n-2)
这个数列与Fibonacci数列有着类似的性质,我们考虑如何计算它某两项的gcd.对于Fibonacci数列我们有:
[此下为Fibonacci数列的性质,关系不大]{
(definition:F)
F(0) = 0
F(1) = 1
F(n) = F(n-1) + F(n-2)
(property:F)
1. F(x) Coprime F(x+1)
2. F(n) Divides F(k*n)
3. gcd(F(x),F(y)) = F(gcd(x,y))
我们来证明一下这些性质,首先是 [1.] 证明:辗转相除显然
这时我们可以发现,只要能证明 [3.] ,就可以推出 [2.] ,具体方法:
(proof:[2.])
假设命题 [3.] 为真:
gcd(F(x),F(k*x))=F(gcd(x,k*x))=F(x)->[2.]
我们考虑如何证明[3.], 我们发现有命题[4.]
(property:F)
4. F(a+b)=F(a)*F(b+1)+F(a-1)*F(b)
(proof:[4.])
考虑对b归纳,
basecase:
F(a+0)=F(a)
F(a+1)=F(a)+F(a-1)
assume forall 0<=b<=t is true, extend to b+1:
F(a+b )=F(a)*F(b+1)+F(a-1)*F(b)
F(a+b-1)=F(a)*F(b )+F(a-1)*F(b-1)
F(a+b+1)=F(a)*F(b+2)+F(a-1)*F(b+1) -> 符合命题
(proof:[3.])
gcd(F(a),F(a+t))=
gcd(F(a),F(a)*F(t+1)+F(a+1)*F(t))=
gcd(F(a),F(a+1)*F(t))=
gcd(F(a),F(t))
应用辗转相减法可得原命题
}
我们现在可以寻找这个T(n)的性质了,仿照寻找F(n)的性质(具体在上面),首先我们要找到T(n)关于很大的T(n+m)的关系.设
(equation:T1)
T(n+m)=T(n)*A(m)+T(n-1)*B(m)
考虑待定系数法
(derivation:T1)
T(n )=T(n)
A(0)=1
B(0)=0
T(n+1)=T(n)*A(1)+T(n-1)*B(1)
A(1)=10
B(1)=1
T(n+m+1)=
T(n+m)*10+T(n+m-1)=
T(n)*A(m)*10+T(n-1)*B(m)*10+T(n)*A(m-1)+T(n-1)*B(m-1)=
T(n)*(A(m)*10+A(m-1))+T(n-1)*(B(m)*10+B(m-1))
A(m+1)=A(m)*10+A(m-1)
B(m+1)=B(m)*10+B(m-1)
<implies that>
A(m)=T(m)
B(m)=T(m-1)
<reduce to>
T(n+m)=T(n)*T(m)+T(n-1)*T(m-1)
(equation:B1)
B(n+m)=T(n+m-1)=T(n)*T(m-1)+T(n-1)*T(m-2)=B(n+1)*B(m)+B(n)*B(m-1)
于是发现了与F(n)完全相同的形式,直接沿用F(n)的证明即可推出gcd(B(x),B(y))=B(gcd(x,y))也即gcd(T(n),T(m))=T(gcd(n+1,m+1)-1)
那么剩下的就是求gcd(c^a+1,c^b+1)(b>a), 我们可以考虑gcd(c^b-c^a,c^b+1)., c^b-c^a = c^(b-a)*(c^(b-a)-1) 显然 c^(b-a) Coprime c^b+1,
gcd(c^a+1,c^b+1)=gcd(c^b-c^a,c^a+1)=gcd(c^|b-2a|-1,c^a+1) 然后就变成了一个类似辗转相减的东西(我还是不很会整个分析),但是打个表就可以知道这东西值是
c^gcd(a,b)+1 a/gcd(a,b),b/gcd(a,b) odd otherwise
2 c even otherwise
1 c odd
然后这道题就做完了吧
PE440的更多相关文章
- ProjectEuler && Rosecode && Mathmash做题记录
退役选手打发时间的PE计划 挂在这里主要是dalao们看到有什么想交流的东西可以私聊哦(站内信或邮箱吧) 2017/8/11 PE595 :第一题QAQ 2017/8/12 PE598 2017/ ...
随机推荐
- LoadLibrary加载动态库失败的解决办法
from:http://blog.sina.com.cn/s/blog_62ad1b8101017qub.html 若DLL不在调用方的同一目录下,可以用LoadLibrary(L"DLL绝 ...
- 分布式光伏系列:分布式光伏电站 运行与维护方案一览(zz)
原文:http://www.toutiao.com/a6353487210709516546/ 中小型光伏电站的特点是占地面积小.安装位置灵活且日常维护量少.由于光伏电站不同的运行环境,为了能够使光伏 ...
- 给大家分享一个jQuery TAB插件演示
jquery tab选项卡插件示例页面代码,使用jquery.tabs.js轻量级的tab选项卡插件来实现,并支持鼠标滑过.点击.自动切换.数据回调等功能,有的是点击切换,有的是鼠标滑过切换,自带了多 ...
- Mongodb学习笔记五(C#操作mongodb)
mongodb c# driver(驱动)介绍 目前基于C#的mongodb驱动有两种,分别是官方驱动(下载地址)和samus驱动(下载地址). 本次我们只演示官方驱动的使用方法. 官方驱动文档查看 ...
- MongoDB的基本操作
环境:CentOS6.8 Mongodb3.2.10 启动 启动mongoDB服务器 # service mongod start 启动mongoDB客户端 # mongo 该客户端是一个JavaS ...
- 私有项目免费使用Git
GitHub,私有项目是要收费了,如果想建立私有项目可以选择GitLab. GitLab注册地址:https://gitlab.com/users/sign_in 本机需要安装git,图形化的工具使用 ...
- bzoj3033
欧拉路,这题好神啊QAQ 显然选择的方案数有2^n种,因为每个点度数都为二所以肯定是一条欧拉路, 第二问直接爆搜即可... ----然而我并没有想到---- 第一问我推出来了(别问我怎么推的,我说我是 ...
- 使用Shell创建GitHub仓库
Github的代码仓库分为2种类型: 用户自己的代码仓库 组织的代码仓库 下面就使用Shell脚本创建这2种类型的代码仓库,脚本如下 创建用户自己的代码仓库 #!/bin/bash USER_NAME ...
- linux下centos的网络连接
- 线程间通信 GET POST
线程间通信有三种方法:NSThread GCD NSOperation 进程:操作系统里面每一个app就是一个进程. 一个进程里面可以包含多个线程,并且我们每一个app里面有且仅有一 ...