欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)現(xiàn)Fibonacci(斐波那契)取余的示例代碼

 更新時(shí)間:2020年03月05日 10:28:46   作者:南墻  
這篇文章主要介紹了Java實(shí)現(xiàn)Fibonacci取余的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

Description
Fibonacci數(shù)列的遞推公式為:Fn=Fn-1+Fn-2,其中F1=F2=1。

當(dāng)n比較大時(shí),F(xiàn)n也非常大,現(xiàn)在我們想知道,F(xiàn)n除以10007的余數(shù)是多少。

Input
多組測(cè)試數(shù)據(jù)

輸入包含一個(gè)整數(shù)n。1 <= n <= 1,000,000。

Output
每組輸出一行,包含一個(gè)整數(shù),表示Fn除以10007的余數(shù)。

Sample Input
10
22

Sample Output
55
7704

利用余數(shù)三大定理:

1.余數(shù)的加法定理

a與b的和除以c的余數(shù),等于a,b分別除以c的余數(shù)之和,或這個(gè)和除以c的余數(shù)。

即:(a+b)%c = (a%c+b%c)%c

例如:23,16除以5的余數(shù)分別是3和1,所以23+16=39除以5的余數(shù)等于4,即兩個(gè)余數(shù)的和3+1.

當(dāng)余數(shù)的和比除數(shù)大時(shí),所求的余數(shù)等于余數(shù)之和再除以c的余數(shù)。

例如:23,19除以5的余數(shù)分別是3和4,故23+19=42除以5的余數(shù)等于3+4=7除以5的余數(shù),即2.

2.余數(shù)的乘法定理

a與b的乘積除以c的余數(shù),等于a,b分別除以c的余數(shù)的積,或者這個(gè)積除以c所得的余數(shù)。

即:(a*b)%c = (a%c*b%c)%c

例如:23,16除以5的余數(shù)分別是3和1,所以23×16除以5的余數(shù)等于3×1=3。

當(dāng)余數(shù)的和比除數(shù)大時(shí),所求的余數(shù)等于余數(shù)之積再除以c的余數(shù)。

例如:23,19除以5的余數(shù)分別是3和4,所以23×19除以5的余數(shù)等于3×4除以5的余數(shù),即2.

3.同余定理

若兩個(gè)整數(shù)a、b被自然數(shù)m除有相同的余數(shù),那么稱a、b對(duì)于模m同余,用式子表示為:a≡b ( mod m ),左邊的式子叫做同余式。

同余式讀作:a同余于b,模m。由同余的性質(zhì),我們可以得到一個(gè)非常重要的推論:

若兩個(gè)數(shù)a,b除以同一個(gè)數(shù)m得到的余數(shù)相同,則a,b的差一定能被m整除

用式子表示為:如果有a≡b ( mod m ),那么一定有a-b=mk,k是整數(shù),即m|(a-b)

那么:如果有mk%m=0,b%m=0,就有(mk+b)%m 

package 第八次模擬;

import java.util.Scanner;
public class Demo12Fibonacci {
public static void main(String[] args) {
 Scanner sc = new Scanner(System.in);
 while(sc.hasNext()){
 
 int n = sc.nextInt();
 int []f = new int [n+2];
 int [] count=new int [n+2];
 f[1]=1;
 f[2]=1;
 for (int i = 3; i <=n; i++) {
 f[i]=(f[i-1]+f[i-2]);
 if(f[i]/10007>=1){
 f[i]%=10007; 
 }
 
 }
 System.out.println(f[n]);
 
 } 
 }
}

 到此這篇關(guān)于Java實(shí)現(xiàn)Fibonacci取余的示例代碼的文章就介紹到這了,更多相關(guān)Java Fibonacci取余內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java從控制臺(tái)讀入數(shù)據(jù)的幾種方法總結(jié)

    Java從控制臺(tái)讀入數(shù)據(jù)的幾種方法總結(jié)

    下面小編就為大家?guī)?lái)一篇Java從控制臺(tái)讀入數(shù)據(jù)的幾種方法總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • Map集合中獲取key-value值的實(shí)現(xiàn)方法

    Map集合中獲取key-value值的實(shí)現(xiàn)方法

    這篇文章主要介紹了Map集合中獲取key-value值的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 使用java實(shí)現(xiàn)BBS論壇發(fā)送郵件過(guò)程詳解

    使用java實(shí)現(xiàn)BBS論壇發(fā)送郵件過(guò)程詳解

    這篇文章主要介紹了使用java發(fā)送郵件過(guò)程詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • SpringBoot注入配置文件的3種方法詳解

    SpringBoot注入配置文件的3種方法詳解

    這篇文章主要介紹了SpringBoot注入配置文件的3種方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • IDEA?2021.3?使用及idea2021.3.1激活使用方法

    IDEA?2021.3?使用及idea2021.3.1激活使用方法

    IDEA?全稱?IntelliJ?IDEA,是java語(yǔ)言開(kāi)發(fā)的集成環(huán)境,IntelliJ在業(yè)界被公認(rèn)為最好的java開(kāi)發(fā)工具之一,今天通過(guò)本文給大家介紹idea2021.3.1激活及使用教程,感興趣的朋友一起看看吧
    2022-01-01
  • Java 超詳細(xì)講解hashCode方法

    Java 超詳細(xì)講解hashCode方法

    在 Java 應(yīng)用程序執(zhí)行期間,在同一對(duì)象上多次調(diào)用 hashCode 方法時(shí),必須一致地返回相同的整數(shù),前提是對(duì)象上 equals 比較中所用的信息沒(méi)有被修改。從某一應(yīng)用程序的一次執(zhí)行到同一應(yīng)用程序的另一次執(zhí)行,該整數(shù)無(wú)需保持一致
    2022-04-04
  • Spring Boot優(yōu)雅地處理404異常問(wèn)題

    Spring Boot優(yōu)雅地處理404異常問(wèn)題

    這篇文章主要介紹了Spring Boot優(yōu)雅地處理404異常問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Spring Boot中使用Spring-data-jpa實(shí)現(xiàn)數(shù)據(jù)庫(kù)增刪查改

    Spring Boot中使用Spring-data-jpa實(shí)現(xiàn)數(shù)據(jù)庫(kù)增刪查改

    本篇文章主要介紹了Spring Boot中使用Spring-data-jpa實(shí)現(xiàn)增刪查改,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。
    2017-03-03
  • springboot2?使用activiti6?idea插件的過(guò)程詳解

    springboot2?使用activiti6?idea插件的過(guò)程詳解

    這篇文章主要介紹了springboot2?使用activiti6?idea插件,本文通過(guò)截圖實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • Java多線程編程之ThreadLocal詳解

    Java多線程編程之ThreadLocal詳解

    這篇文章主要介紹了Java多線程編程之ThreadLocal詳解,ThreadLocal是Java中的一個(gè)線程局部變量,該變量在多線程并發(fā)執(zhí)行時(shí),為每個(gè)線程都提供了一個(gè)獨(dú)立的副本,簡(jiǎn)單來(lái)說(shuō),ThreadLocal提供了一種在多線程環(huán)境中,使每個(gè)線程綁定自己獨(dú)立的變量的方法,需要的朋友可以參考下
    2023-09-09

最新評(píng)論