解题思路:

按照动规五部曲:

  1. 定义动规数组和数组下标的含义:dp[i]表示:dp数组中第i个菲波那契数的值

   2.确定递推公式:
                                dp[i]=dp[i-1]+dp[i-2];}
     进而简化成:
                                sum=dp[1]+dp[0];
                                dp[0]=dp[1];
                                dp[1]=sum;
                          

 3.初始化dp数组(清楚递推公式后才清楚如何初始化数组): dp[0]=0  ;dp[1]=1;

 4.确定遍历方式:从前往后遍历

 5.打印dp[]数组
注意事项:

参考代码:

package com.wyh.dynamic;

import java.util.Scanner;

public class Main {
   public static void main(String[] args) {
       Scanner scanner=new Scanner(System.in);
       int n=scanner.nextInt();
       int [] dp=new int[2];
       //初始化dp数组
       dp[0]=0;
       dp[1]=1;
       //用于存储结果
       int sum=0;
       //递推公式
       if (n<2){
           System.out.println(1);
           return;
       }else {
           for (int i=2;i<=n;i++){
               sum=dp[1]+dp[0];
               dp[0]=dp[1];
               dp[1]=sum;
           }
           System.out.println(dp[1]);
       }
   }
}

点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论