蓝桥杯习题-2019 第十届-研究生组-Fibonacci数列-java

蓝桥杯习题-2019 第十届-研究生组-Fibonacci数列-java
题目:
在这里插入图片描述
难点:
不会保留8位小数,笨蛋啊,使用类进行保留不足8位时进行补0

代码

import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.util.Scanner;

public class Fabii数列 {
    /*Fibonacci 数列是非常著名的数列:F[1] = 1, F[2] = 1,
    对于 i > 3,F[i] = F[i 1] + F[i 2]
    Fibonacci 数列有一个特殊的性质,前一项与后一项的比值,F[i]/F[i + 1],
    会趋近于黄金分割。
    为了验证这一性质,给定正整数 N,请你计算 F[N]/F[N + 1],并保留 8 位小数。
   【输入格式】
    一个正整数 N。(1 ≤ N ≤ 2000000000)
    【输出格式】
     F[N]/F[N + 1]。答案保留 8 位小数。*/
    //第一输入一个数N
    public static void main(String[] args) {
        //int N = 2;
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        String a = String.valueOf(compu(n));
        System.out.println(a);

    }
    //递归形式的调用找到F(N)
    public static int fa(int n){
        //对n进行计算
        if(n==1){
            return 1;
        }
        if(n==2){
            return 1;
        }
        else{ return fa(n-1) +fa(n-2);}
    }
    //递归出口是F1,F2
    public static String compu(int n){
        //f(n)/f(n+1)
        int n1 = fa(n);
        System.out.println(n1);
        int n2 = fa(n+1);
        System.out.println(n2);
        //大数操作
        BigDecimal bigA = new BigDecimal(n1);
        BigDecimal bigB = new BigDecimal(n2);
        //补0操作
        double res = bigA.divide(bigB, 8, RoundingMode.HALF_UP).doubleValue();
        // 不足两位小数补0
        DecimalFormat decimalFormat = new DecimalFormat("0.00000000#");
        String strVal = decimalFormat.format(res);
        System.out.println(strVal);
        return strVal;

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值