java黄金连分数_蓝桥杯 | Java B组省赛真题练习——黄金连分数-Go语言中文社区...

标题: 黄金连分数

黄金分割数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位数字,请通过浏览器直接提交该数字。

注意:不要提交解答过程,或其它辅助说明类的内容。

解题思路:

识别问题等价于斐波那契的n项和n+1项的比值,n要多少才够,怎么处理很大的数和精度要求很高的浮点数。

1.化为求斐波那契相邻两项的比值,到多少项?越多越精确,n/n+1项,n再往上增加,这个比值的小数点后101位是稳定的,也就是不变的。

2.double无法表示100位小数,BigInteger和BigDecimal。

实现代码:

package java_B_2013;

import java.math.BigDecimal;

import java.math.BigInteger;

public class _04_黄金连分数 {

public static void main(String[] args) {

BigInteger a=BigInteger.ONE;

BigInteger b=BigInteger.ONE;

//斐波那契数列的迭代形式

for (int i = 3; i < 500; i++) {

BigInteger t=b;

b=a.add(b);//大整数的加法

a=t;

}

//大浮点数的除法

BigDecimal divide = new BigDecimal(a,110).divide(new BigDecimal(b,110), BigDecimal.ROUND_HALF_DOWN);

//截取字符串

System.out.println(divide.toPlainString().substring(0,103));

}

}

运行结果:

4247efd9059d5fd7c55824ab66dce26c.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/528709.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python 数组维度_python – 非常基本的Numpy数组维度可视化

NumPy中ndarray的解剖结构如下所示&#xff1a;(来源&#xff1a;Physics Dept, Cornell Uni)一旦离开2D空间并进入3D或更高维空间,行和列的概念就不再有意义了.但是你仍然可以直观地理解3D阵列.例如,考虑你的例子&#xff1a;In [41]: bOut[41]:array([[[ 1, 2, 3],[ 4, 5, 6]…

Java捕获异常密码_Java捕获异常的问题

---恢复内容开始---在Java编译过程中&#xff0c;有时候会出现输入未按照规定输入的情况&#xff0c;此时需要警告用户输入错误&#xff0c;这就会是程序运行过程中出现异常。异常就是可预测但是又没办法消除的一种错误。所以在编写过程中&#xff0c;为了在程序当中不发生这样…

java作业四_Java第四次作业

1.(二次方程式)为二次方程式ax2bxc0设计一个名为QuadraticEquation的类。这类包括&#xff1a;(1)代表三个系数的私有数据域a、b、c(2)一个参数为a、b和c的构造方法(3)a、b、c的三个get方法(4)一个名为getDiscriminant()的方法返回判别式&#xff0c;b2-4ac(5)一个名为getRoot1…

java collectiongroup 类_Java中的collection集合类型总结

java集合是java提供的工具包&#xff0c;包含了常用的数据结构&#xff1a;集合、链表、队列、栈、数组、映射等。java集合工具包位置是java.util.*java集合主要可以划分为4个部分&#xff1a;list列表、set集合、map映射、工具类(iterator迭代器、enumeration枚举类、arrays和…

php 鼠标点击图片放大,css3如何实现鼠标放上图片放大?(附代码)

在css3的学习中&#xff0c;我们会经常做一些小的动画效果&#xff0c;这感觉非常有趣&#xff0c;所以今天的这篇文章将给大家来介绍关于css3实现图片放大的一个效果&#xff0c;有兴趣的小伙伴可以看一下。我们都知道css3中增加了一个transform属性应用于元素的2D或3D转换&am…

脉位调制解调 matlab,通信原理与matlab仿真v2 第五章 DBPSK调制解调器(1)

在毕业设计的相关课程中&#xff0c;已经提及了这个DPSK调制方式。不过如果把它放在理论教学课程中来讲&#xff0c;就需要补充一些基本知识。当然还会给同学们看一下实际在卫星通信中使用的DBPSK程序。之前讲到了BPSK&#xff0c;回顾一下发送滤波器的知识吧。由于信号要在信道…

matlab地址数据类型uns,使用matlab生成sine波mif文件

使用matlab生成sine波mif文件作者&#xff1a;lee神在使用altera 的FPGA中的rom過程中常常會使用到.mif文件或.hex文件。對於初學者&#xff0c;無論mif還是hex都是很令人疑惑的東西&#xff0c;這里就對mif文件的格式及其創建做一點簡單的說明。Mif是memory initialization fi…

OpenAI科学家Hyung Won Chung演讲精华版

文章目录 第一个观点&#xff1a;涌现第二个观点&#xff1a;如何扩大规模1、标记化2、嵌入3、计算4、评估&#xff08;损失函数&#xff09;5、反向传播 最近从Google跳槽到OpenAI的AI科学家 Hyung Won Chung 比较拗口&#xff0c;我就简称尚哥了 他最近做了一个技术演讲 …

php如何实现购物时数量增减,1、vuex状态管理--购物车数量增减

GIF.gif1、购物车数量增减-import { mapState,mapMutations} from vuex //引入mapState、mapMutations映射函数export default{computed:{...mapState({changableNum:state > state.headerStatus.changableNum, //用模块headerStatus里的状态 changableNumdisabled:state &g…

oracle中存储过程和函数有什么区别,Oracle中存储过程和函数的区别

Oracle中存储过程和函数的区别存储过程和函数&#xff1a; www.2cto.com例子&#xff1a;[sql]//创建过程create or replace procedure add_emailinfo(namee email_info.fullname%type &#xff0c;address email_info.email_address%type )isbegininsert into email_info(ful…

oracle 查询结果升序,Oracle学习日志-8(查询结果排序)

要用到的表如下书上写到&#xff0c;上面的查询结果排序是随机的&#xff0c;再执行几次结果可能不同&#xff0c;但是我执行多次后&#xff0c;查询结果的排序都是如此&#xff0c;是因为oracle的默认处理方式是按照物理储存顺序查询的&#xff0c;而我在插入记录的时候都是按…

linux下如何搜索某个文件,技术|如何在 Linux 中查找一个文件

对于新手而言&#xff0c;在 Linux 中使用命令行可能会非常不方便。没有图形界面&#xff0c;很难在不同文件夹间浏览&#xff0c;找到需要的文件。本篇教程中&#xff0c;我会展示如何在 Linux 中查找特定的文件。第一步要做的是find 命令&#xff0c;另外一种是使用 locate 命…

linux 安装系统 逻辑卷,Linux逻辑卷工具lvm的使用教程

创建逻辑卷(LVM)详细方法&#xff1a;STEP 1&#xff1a;首先用fdisk命令建立物理分区&#xff0c;然后将每个分区类型转换为LVM类型&#xff0c;编号为8e&#xff0c;如果是对整个磁盘建立pv的话这步可以忽略。STEP 2&#xff1a;使用pvcreate命令建立pv&#xff0c;也就是物理…

linux下su命令进不去,Linux系统中的切换用户Su命令,教你如何使用su命令,包括注意事项...

在本文中&#xff0c;我们将解释如何使用su命令&#xff0c;su(替换或切换用户的缩写)实用程序允许你使用其他用户的权限运行命令&#xff0c;默认情况下是root用户。使用su是在当前登录会话中切换到管理帐户的最简单方法&#xff0c;当root用户不允许通过ssh或使用GUI显示管理…

linux收回用户执行权限,Linux之文件权限管理命令

一、查看文件属性。1、命令ls -l filename 查看长格式形式查看文件详细属性。ls -l file1 ##查看文件file1的详细属性结果&#xff1a;- |rw-r--r--| 1 |kiosk| kiosk| 0| Jul 21 09:18 | file1[1] [2] [3] [4] [5] [6] [7] [8][1] 文件的类型—##空文件&#xff0c;或者文本d#…

linux服务器操作系统日志都有哪些,Linux操作系统服务器日志管理详解

Linux操作系统服务器日志管理详解Linux操作系统服务器日志管理详解日志对于安全来说&#xff0c;非常重要&#xff0c;他记录了系统每天发生的各种各样的事情&#xff0c;你可以通过他来检查错误发生的原因&#xff0c;或者受到攻击时攻击者留下的痕迹。日志主要的功能有&#…

linux7配置dns服务器,centOS7搭建DNS服务器配置详解

写在前言&#xff1a;DNS服务器中 named-checkconf -z /etc/named.conf 命令用来检查所有与DNS有关的配置文件&#xff0c;若有错误&#xff0c;会直接提示&#xff0c;可以代替相关的所有检查命令。通过yum安装所需的BIND软件&#xff0c;系统光盘中自带了BIND服务的安装文件。…

linux重新安装xrog文件,Linux下重新生成xorg.conf

较新版本的Linux系统都已经没有xorg.conf文件&#xff0c;但是有时候为了对显示做微调或为了支持多屏显示等原因&#xff0c;还需要手工生成一个xorg.c较新版本的Linux系统都已经没有xorg.conf文件&#xff0c;但是有时候为了对显示做微调或为了支持多屏显示等原因&#xff0c;…

linux获取weblogic版本,LINUX查看JDK和Weblogic版本命令

满意答案xjiank2014.05.03采纳率&#xff1a;50% 等级&#xff1a;12已帮助&#xff1a;4893人JDKA、查找目前所使用的linux下所使用的jdk安装后的目录&#xff1a;echo $JAVA_HOME&#xff1b;B、获得目前所使用的linux下所使用的jdk的版本java -version&#xff1b;C、获得…

如何知道linux的ssh秘钥是否匹配,SSH密钥验证

[SSH登录两种方式验证](一)&#xff1a;用户名密码验证 说明&#xff1a;1.客户机向服务器发送SSH连接请求2.服务器收到请求&#xff0c;发送一个公钥给客户机3.客户机收到公钥&#xff0c;对输入的用户名密码进行加密返回给服务器4.服务器收到加密信息利用私钥解密对比用户…