斐波那契数列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/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

发表回复

登录后才能评论