第四届蓝桥杯JavaB组省赛-黄金连分数

第四届蓝桥杯JavaB组省赛-黄金连分数

题目描述

题目描述
黄金分割数0.61803… 是个无理数,这个常数十分重要,在许多工程问题中会出现。有时需要把这个数字求得很精确。

对于某些精密工程,常数的精度很重要。也许你听说过哈勃太空望远镜,它首次升空后就发现了一处人工加工错误,对那样一个庞然大物,其实只是镜面加工时有比头发丝还细许多倍的一处错误而已,却使它成了“近视眼”!!

言归正传,我们如何求得黄金分割数的尽可能精确的值呢?有许多方法。

比较简单的一种是用连分数:

                                1
黄金数 = ------------------------------
                                 1
                1 + ---------------------
                                    1
                       1 + -------------
                                      1
                             1 + -------
                                   1 + ...

                       

这个连分数计算的“层数”越多,它的值越接近黄金分割数。

请你利用这一特性,求出黄金分割数的足够精确值,要求四舍五入到小数点后100位。

小数点后3位的值为:0.618
小数点后4位的值为:0.6180
小数点后5位的值为:0.61803
小数点后7位的值为:0.6180340

(注意尾部的0,不能忽略)

你的任务是:写出精确到小数点后100位精度的黄金分割值。

注意:尾数的四舍五入! 尾数是0也要保留!

显然答案是一个小数,其小数点后有100位数字,请通过浏览器直接提交该数字。
注意:不要提交解答过程,或其它辅助说明类的内容。

解题过程

需要使用JAVA中的大数运算的相关知识,这个是关键,如果对这方面知识不明确做的会很迷茫…通过对大佬题解的学习,学习到三种方法可以解题,最先学会的是循环直接运算的方法,这种方法我感觉好理解一些;第二种是斐波那契数列的解法,这种方法需要看出这个斐波那契数列的规律之后也是挺好写出来的;第三种就是第一种循环的递归写法,感觉递归会比循环稍微难理解一些…

相关知识的链接:
BigDecimal中divide方法详解.
BigDecimal.setScale用法.
蓝桥杯 黄金连分数(java题解).

要点总结

1.BigDecimal类的使用
2.题意的理解,当除的值一定大时结果稳定
3.斐波那契规律的总结

代码

第一种 循环做法

public static void main(String[] args) {
   
        //定义大范围数值
        BigDecimal bt=new BigDecimal(1);
        //循环操作1000次
        //这里的一千可以是其他数,只要实验一个数几次发现结果不在发生变化就可以
        for (int i=0;i<
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值