1.计算(a/b)%c,其中b能整除a

设a=b*r=(bc)*s+b*t

则(b*t)为a除以bc的余数

r=c*s+t

(a/b)%c=r%c=t

(a%bc)/b=(b*t)/b=t

所以对于b与c互素和不互素都有(a/b)%c=(a%bc)/b成立。

当bc不大时,先取模bc,再除b

如果b与c互素,则(a/b)%c=a*b^(phi(c)-1)%c

待证

2.与集合子集

斐波那契数列的第n+2项同时也代表了集合{1,2,...,n}中所有不包含相邻正整数的子集个数。

证明:归纳法证明——

n=1时,相应子集个数为2,为f(3);

n=2时,相应子集个数为3,为f(4);

n>=3时,若集合{1,2,...,n-2}的相应子集为f(n),集合{1,2,...,n-1}的相应子集为f(n-1)

则对于集合{1,2,...,n}:

包含n的子集(即不包含n-1,在最大项可以为n-2的子集基础上加上数字n)个数为f(n)

不包含n的子集个数为f(n+1)(最大项可以为n-1的子集)

所以集合{1,2,...,n}的相应子集为f(n)+f(n+1)=f(n+2)

所以得证

3.gcd(fib(n),fib(m))=fib(gcd(n,m))

证明:http://www.cnblogs.com/cmyg/p/6618893.html

当一个数n与其它数m的最大公约数为为1或2时,则fib(n)和fib(m)的最大公约数为fib(1)或fib(2),为1。

 #include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <malloc.h>
#include <memory.h> #define ansnum 20000000
#define anszhi 2000000 struct node
{
long long mat[][];
};
long *zhi;
bool *vis;
long yu; void Prime()
{
long i,j,ans=;
memset(vis,true,sizeof(bool)*ansnum);
for (i=;i<ansnum;i++)
{
if (vis[i])
{
ans++;
zhi[ans]=i;
}
for (j=;j<=ans;j++)
{
if (i*zhi[j]>=ansnum)
break;
vis[i*zhi[j]]=false;
if (i%zhi[j]==)
break;
}
}
zhi[]=;
zhi[]=;
} struct node count_mat(struct node a,struct node b)
{
long i,j;
struct node c;
for (i=;i<;i++)
for (j=;j<;j++)
c.mat[i][j]=(a.mat[i][]*b.mat[][j]
+a.mat[i][]*b.mat[][j])%yu;
return c;
} long fib(long t)
{
struct node m,r;
m.mat[][]=;
m.mat[][]=;
m.mat[][]=;
m.mat[][]=; r.mat[][]=;
r.mat[][]=;
r.mat[][]=;
r.mat[][]=;
t--;
while (t)
{
if ((t & )==)
r=count_mat(r,m);
t>>=;
m=count_mat(m,m);
}
return (r.mat[][]+r.mat[][])%yu;
} int main()
{
vis=(bool *) malloc (sizeof(bool)*ansnum);
zhi=(long *) malloc (sizeof(long)*anszhi);
long n,k,x,m,i,j;
Prime();
scanf("%ld",&n);
for (i=;i<=n;i++)
{
scanf("%ld%ld%ld",&k,&x,&m);
yu=x;
for (j=zhi[k];;j++)
if (fib(j)==)
break;
yu=x*m;
printf("%ld\n",fib(j)/x);
}
return ;
}
/*
5
5 13 10
1 11 3
5 2 5
5 5 6
1000000 100 1000000
*/

最新文章

  1. Tomcat启动超过45S
  2. HDU2955 背包DP
  3. Idea 201601注册码
  4. SQL实现分组查询取前几条记录
  5. [转]我来Hacking JDBC,你并不需要它
  6. Android开发之旅:环境搭建及HelloWorld
  7. elfiner-servlet 2.x已开源!
  8. 浪潮MegaCli
  9. SpringMVC 流程 配置 接口
  10. Extjs通过structs2生成树结构
  11. ARP劫持攻击
  12. HUST 1352 Repetitions of Substrings(字符串)
  13. 【LeetCode】190. Reverse Bits
  14. Mat, IplImage, CvMat, Cvarr关系及元素获取
  15. C#开发WEBService服务 C++开发客户端调用WEBService服务
  16. https基础
  17. MATLAB运行edge函数闪退
  18. js变量浅谈
  19. 【Python】 sort、sorted高级排序技巧
  20. 解决Mac上安装mysqlclient的错误

热门文章

  1. 关于Win10下IE11只能以管理员身份运行的处理方式
  2. 时区提示:Local time zone must be set--see zic manual page 2018的解决办法
  3. 《Linux内核分析》第六周学习笔记
  4. python语言几个常见函数的使用
  5. ☆C++学习心得
  6. shell脚本--cut命令与awk简单使用
  7. HDU 5702 Solving Order
  8. Redis交互编程语言及客户端
  9. FreeMarker example all in one
  10. CSS 范围选择器(自编)