斐波那契數列java,斐波那契數列javascript

本文目錄一覽:

java 斐波那契數列

import java.util.Scanner;

/**

 * 斐波那契數列:第0項是0,第1項是第一個1。

這個數列從第三項開始,每一項都等於前兩項之和

 * @author young

 *

 */

public class Fei {

public static void func(int n) {

if (n  3) {

System.out.println(“0,1”);

} else if (n  3) {

int a=0, b=1, c=0;

  System.out.print(a + ”    ” + b + ”    “);

  for (int i = 3; i = n; i++) {

   c = a + b;

   a = b;

   b = c;

   System.out.print(c + ”    “);

  }

} else if (n  0) {

System.out.println(“輸入數字不符合要求”);

}

}

public static void main(String[] args) {

Fei f = new Fei();

Scanner input = new Scanner(System.in);

System.out.print(“請輸入斐波那契數列的列數n,按ENTER:”);

int num = input.nextInt();

System.out.println(“斐波那契數列為:” ); 

func(num);

}

}

正確的代碼

用JAVA數組來求斐波那契數列前20項: 1 1 2 3 5 8 ….

public class Demo {

    public static void main(String[] args) {

 

        int n = 20;

        int sum = 0;

        for (int i = 1; i = n; i++) {

            System.out.print(fibo(i) + “\t”);

            sum +=fibo(i);

        }

        System.out.println(“\n菲波那契數列的前20項和為:”+sum);

    }

 

    private static int fibo(int n) {

        if (n == 1)

            return 1;

        if (n == 2)

            return 1;

        return fibo(n – 1) + fibo(n – 2);

    }

}

數組法:

public class Demo {

    public static void main(String[] args) {

        int []array=new int[20];

        array[0]=1;

        array[1]=1;

        int sum = 0;

        for (int i=2;iarray.length;i++ ){

           array[i]=array[i-1]+array[i-2];

        }

        //遍曆數組並累計

        for (int i=0;iarray.length;i++ ){

             sum +=array[i];

        }

        //輸出和

        System.out.println(“\n菲波那契數列的前20項和為:”+sum);

    }

}

如何用java語言輸出斐波那契數列

Java編程:三種方法實現斐波那契數列

其一方法:

public class Demo2 {  

    // 定義三個變數方法  

    public static void main(String[] args) {  

        int a = 1, b = 1, c = 0;  

        System.out.println(“斐波那契數列前20項為:”);  

        System.out.print(a + “\t” + b + “\t”);  

        //因為前面還有兩個1、1 所以i=18  

        for (int i = 1; i = 18; i++) {  

            c = a + b;  

            a = b;  

            b = c;  

            System.out.print(c + “\t”);  

            if ((i + 2) % 5 == 0)  

                System.out.println();  

        }  

    }  

  

}

java編程:三種方法實現斐波那契數列

其二方法:

public class Demo3 {  

    // 定義數組方法  

    public static void main(String[] args) {  

        int arr[] = new int[20];  

        arr[0] = arr[1] = 1;  

        for (int i = 2; i  arr.length; i++) {  

            arr[i] = arr[i – 1] + arr[i – 2];  

        }  

        System.out.println(“斐波那契數列的前20項如下所示:”);  

        for (int i = 0; i  arr.length; i++) {  

            if (i % 5 == 0)  

                System.out.println();  

            System.out.print(arr[i] + “\t”);  

        }  

    }  

  

}

Java編程:三種方法實現斐波那契數列

其三方法:

public class Demo4 {  

    // 使用遞歸方法  

    private static int getFibo(int i) {  

        if (i == 1 || i == 2)  

            return 1;  

        else  

            return getFibo(i – 1) + getFibo(i – 2);  

    }  

  

    public static void main(String[] args) {  

        System.out.println(“斐波那契數列的前20項為:”);  

        for (int j = 1; j = 20; j++) {  

            System.out.print(getFibo(j) + “\t”);  

            if (j % 5 == 0)  

                System.out.println();  

        }  

    }  

  

}

同一道題用各種不同的思路去思考解決,也是對知識綜合運用的鍛煉。

java語言解決斐波那契數列問題

public

class

zuoye{

public

static

void

main(String[]

args){

int

num1=1,num2=1;//設定前兩位數初始值

int

num=0;

//把變數mun賦值為0是什麼意思?在後面有什麼用?

答:

num賦值初始化為0,

不然為null.

System.out.println(num1+”\\t”+num2+”\\t”+(num1+num2));

//顯示輸出數列的前三位

這個上面的列印的結果和後面循環的結果應該是分開的,也就是前面列印

1

1

2

然後換行,然後再通過循環列印10個數字.

接下來我們看循環部分.

斐波那契數列公式是

F1=1

(n=1)

F2=1

(n=2)

Fn=F(n-1)+F(n-2)

(n=3)

所以,

for(int

i=1;i=10;i++){

//for循環

int

num3=num+num2;

//num+num2

??num加num2幹什麼?

答:num是個中間變數,

用來傳值,

賦給num的值永遠是F(n-1)

num2=num;

//為什麼又把num賦值給num2?

答:

賦給num2的值永遠是F(n-2).

這裡因為num的值在上一個循環里為F(n-1),到下一個循環應該是F(n-2).所以賦給num2.

num=num3;

//

num3再賦給num?

答:

因為賦給num的值永遠是F(n-1),

這裡因為num3的值到下一個循環應該就是F(n-1).所以賦給num.

System.out.print(“\\t”+num3);

if(i%5==0){

//i能被5整除.為什麼要設定一個這樣的判斷條件?

答:

這裡是每五個數列印一個換行符.

System.out.println();

//輸出空的是什麼意思?

答:

這裡是列印一個換行符

}

}

}

}

JAVA大神求教,斐波那契數列大家都非常熟悉

public class Fibonacci {

public static void main(String[] args) {

show1();////定義數組方法

show2();//使用遞歸方法  

show3();//定義三個變數方法 

}

//方法1:定義數組方法

private static void show1() {

int arr[] = new int[20];  

        arr[0] = arr[1] = 1;  

        for (int i = 2; i  arr.length; i++) {  

            arr[i] = arr[i – 1] + arr[i – 2];  

        }  

        System.out.println(“斐波那契數列的前20項如下所示:”);  

        for (int i = 0; i  arr.length; i++) {  

            if (i % 5 == 0)  

                System.out.println();  

            System.out.print(arr[i] + “\t”);  

        }  

    }

//方法2:使用遞歸方法 

 public static void show2() {  

        System.out.println(“\n\n斐波那契數列的前20項為:”);  

        for (int j = 1; j = 20; j++) {  

            System.out.print(getFibo(j) + “\t”);  

            if (j % 5 == 0)  

                System.out.println();  

        }  

    }  

    private static int getFibo(int i) {  

        if (i == 1 || i == 2)  

            return 1;  

        else  

            return getFibo(i – 1) + getFibo(i – 2);  

    }

    //方法3:定義三個變數方法 

    private static void show3() {

     int a = 1, b = 1, c = 0;  

        System.out.println(“\n\n斐波那契數列前20項為:”);  

        System.out.print(a + “\t” + b + “\t”);  

        //因為前面還有兩個1、1 所以i=18  

        for (int i = 1; i = 18; i++) {  

            c = a + b;  

            a = b;  

            b = c;  

            System.out.print(c + “\t”);  

            if ((i + 2) % 5 == 0)  

                System.out.println();  

        }  

    }

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/250512.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-13 13:29
下一篇 2024-12-13 13:29

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字元串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字元串中是否存在多個指定字元: 一、字元串遍歷 字元串是Java編程中非常重要的一種數據類型。要判斷字元串中是否存在多個指定字元…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論