一些证明,推荐复制入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/ ...
随机推荐
-
linux 踢出用户方法
linux系统root用户可强制踢制其它登录用户, 首先以root登录以便查看全部的在线用户信息,可用w命令查看登录用户信息 强制踢人命令格式:pkill -kill -t tty 解释: pkill ...
-
.NET依托CLR进行的内存的管理
看了http://www.cnblogs.com/liulun/p/3145351.html 不错,补习下相关技术.. 正文: .NET依托CLR进行的内存的管理 有了CLR 基本不需要担心.net ...
-
IOS中UITextView(多行文本框)控件的简单用法
1.创建并初始化 UITextView文本视图相比与UITextField直观的区别就是UITextView可以输入多行文字并且可以滚动显示浏览全文.UITextField的用处多,UITextVie ...
-
Python04(基础语法)
Trainning-day03回顾1.输出重定向 > 将输出到终端的内容输出到指定文件 命令 > 文件 注意: 1.如果文件存在,覆盖原文件 2.如果文件不存在,直接创建新文件2.输出追加 ...
-
Postman 设置全局变量和环境变量设置(之 图形界面设置变量)
在Postman中有两种方法添加变量:1.图形界面操作添加 2.执行代码添加 1.图形界面操作添加,点击右上角齿轮按钮手动添加所需测试环境: 2.点击右上角的小眼睛可以编辑.添加“全局变量”和 ...
-
高程小tips
1.DOM操作往往是JS程序中开销最大的部分,应尽量减少DOM操作.-P285 P297例子 2.元素的classList属性: 元素的classLis即该元素的class的值的集合,是一个列表(数 ...
-
linux如何在不重新登录用户的情况下使用户加入的组生效
这个问题在很早之前就遇到了,之前的解决方法是登出用户再登录用户.今天在配置virtualbox的过程中又遇到了同样的问题.于是又进行了一番搜索. 找到了如下答案: https://stackoverf ...
-
移动端1px边框问题
用于手机端受dpr的影响,实际开发中,PC端和移动端展示的效果不太一样,往往在PC端显示的是1px,移动端常常是偏粗一些. 解决办法: 主要是用到伪类及缩放.在需要画边框的元素上,设置一个伪类,它的伪 ...
-
二十四种设计模式:建造者模式(Builder Pattern)
建造者模式(Builder Pattern) 介绍将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 示例用同样的构建过程创建Sql和Xml的Insert()方法和Get()方 ...
-
CWinApp类CMultiDocTemplate类CDocument类CView类的关系
转自:http://blog.csdn.net/bboot/article/details/26884011 不得不转,瞬间搞清了很多问题,短小精悍 1.CWinApp类 它包含并管理着应用程序的 ...