日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

zoj 3707 Calculate Prime S

發布時間:2024/2/28 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 zoj 3707 Calculate Prime S 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

fibonacci數列的性質:

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

證明:可以通過反證法先證fibonacci數列的任意相鄰兩項一定互素,然后可證n>m時gcd(fib(n),fib(m))=gcd(fib(n-m),fib(m)),遞歸可

求gcd(fib(n),fib(m))=gcd(fib(k),fib(l)),最后k=l,不然繼續遞歸。K是通過展轉相減法求出,易證k=gcd(n,m),所以gcd(fib(n),fib(m))

=fib(gcd(n,m))。

?

2.如果fib(k)能被x整除,則fib(k*i)都可以被x整除。

3.f(0)+f(1)+f(2)+…+f(n)=f(n+2)-1

4.f(1)+f(3)+f(5)+…+f(2n-1)=f(2n)

5.f(2)+f(4)+f(6)+…+f(2n)?=f(2n+1)-1

6.[f(0)]^2+[f(1)]^2+…+[f(n)]^2=f(n)·f(n+1)

7.f(0)-f(1)+f(2)-…+(-1)^n·f(n)=(-1)^n·[f(n+1)-f(n)]+1

8.f(n+m)=f(n+1)·f(m)+f(n)*f(m-1)

9.[f(n)]^2=(-1)^(n-1)+f(n-1)·f(n+1)

10.f(2n-1)=[f(n)]^2-[f(n-2)]^2

11.3f(n)=f(n+2)+f(n-2)

12.f(2n-2m-2)[f(2n)+f(2n+2)]=f(2m+2)+f(4n-2m)?[?n〉m≥-1,且n≥1]

?

還有一個結論:

計算(a/b)%c??其中b能整除a

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

如果b與c不互素,則(a/b)%c=(a%bc)/b

對于b與c互素和不互素都有(a/b)%c=(a%bc)/b成立


附上代碼:

#include<cstdio> #include<cstring> #include<iostream> using namespace std;#define LL long long struct matrix{LL f[2][2]; };const int N=16000000; int prime[16000000]; LL p[13000011];void init(){int i,j;int k=1;memset(prime,0,sizeof(prime));p[0]=1;k=1;for(i=2;i<=N;i++){if(prime[i]==0){p[k++]=i;for(j=2*i;j<=N;j+=i){prime[j]=1;}}}p[1]=3;p[2]=4; }matrix multi(matrix a,matrix b,int MOD) {struct matrix c;int i,j,k;for(i=0;i<2;i++){for(j=0;j<2;j++){c.f[i][j]=0;for(k=0;k<2;k++){c.f[i][j]=(c.f[i][j]+(a.f[i][k]*b.f[k][j])%MOD)%MOD;}}}return c; }matrix quick_pow(int k,int MOD) {int i;struct matrix s;memset(s.f,0,sizeof(s.f));for(i=0;i<2;i++) s.f[i][i]=1;struct matrix a;a.f[0][0]=1;a.f[0][1]=1;a.f[1][0]=1;a.f[1][1]=0;while(k){if(k&1){s=multi(s,a,MOD);}a=multi(a,a,MOD);k=k>>1;}return s; }int main(){int i,k,x,m;int t;init();scanf("%d",&t);struct matrix ans;while(t--){scanf("%d%d%d",&k,&x,&m);for(i=p[k];;i++){ans = quick_pow(i-1,x);if(ans.f[0][0]%x==0) break;}ans = quick_pow(i-1,x*m);printf("%lld\n",ans.f[0][0]/x);}return 0; }

總結

以上是生活随笔為你收集整理的zoj 3707 Calculate Prime S的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。