前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >③【Java 组】蓝桥杯省赛真题 [黄金连分数][马虎的算式]持续更新中...

③【Java 组】蓝桥杯省赛真题 [黄金连分数][马虎的算式]持续更新中...

作者头像
.29.
发布2023-10-17 17:30:18
2160
发布2023-10-17 17:30:18
举报
文章被收录于专栏:个人技术博客

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~

蓝桥杯真题--持续更新中...

一、黄金连分数(填空)


题目描述

在这里插入图片描述
在这里插入图片描述

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

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

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

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

代码语言:javascript
复制
                  1
    黄金数 = ---------------------
                        1
             1 + -----------------
                          1
                 1 + -------------
                            1
                     1 + ---------
                          1 + ...

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

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

小数点后3位的值为:0.618;

小数点后4位的值为:0.6180;

小数点后5位的值为:0.61803;

小数点后7位的值为:0.6180340。 (注意尾部的 00,不能忽略)

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

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

解题思路: 根据题目给到黄金数的连分数示意图,我们可以发现,相邻层级之间的数是有关联的: ① 黄金数的分母 = 上一层数 分母+分子 ② 黄金数的分子 = 上一层数分母 而分子以及分母的变化,恰巧就是斐波那契数列,那么我们就将问题转换成了求斐波那契额相邻两个数的比值。 同时题目要求写出精确到小数点后 100 位精度的黄金分割值,浮点数已经无法满足如此多的小数位,所以需要使用使用BigInteger和BigDecimal。

解题代码:

代码语言:javascript
复制
import java.math.BigDecimal;
import java.math.BigInteger;

//求斐波那契额相邻两个数的比值,需要保证小数点后101位准确,使用BigInteger和BigDecimal
public class 黄金连分数 {
	public static void main(String[] args) {
		BigInteger a = BigInteger.ONE; //a代表分子
		BigInteger b = BigInteger.ONE; //b代表分母
		
		for(int i = 3;i < 500;i++) { //第一层是 1/1 (已知),所以从第三个数开始
			BigInteger temp = b;
			b = a.add(b);       //黄金数的分母 = 上一层数 分母+分子
			a = temp;           //黄金数的分子 = 上一层数分母
		}
		
		//创建BigDecimal对象,小数点没有限制;
		//divide()方法表示除法运算
		BigDecimal divide = new BigDecimal(a,110).divide(new BigDecimal(b,110),BigDecimal.ROUND_HALF_DOWN);
		
		//输出黄金分割数,精确到101位(103代表字符数,包含0和.)
		System.out.println(divide.toPlainString().substring(0,103));
		//0.61803398874989484820458683436563811772030917980576286213544862270526046281890244970720720418939113748
		//小数点后101位,我们需要四舍五入至100位
		//0.6180339887498948482045868343656381177203091798057628621354486227052604628189024497072072041893911375
	}

}
代码语言:javascript
复制
答案:0.6180339887498948482045868343656381177203091798057628621354486227052604628189024497072072041893911375

二、马虎的算式(填空)


题目描述

在这里插入图片描述
在这里插入图片描述

文字版: 小明是个急性子,上小学的时候经常把老师写在黑板上的题目抄错了。

有一次,老师出的题目是:36x495=?

他却给抄成了:396x45=?

但结果却很戏剧性,他的答案竟然是对的!!

因为 36∗495=396∗45=17820。

类似这样的巧合情况可能还有很多,比如:27∗594=297∗54。

假设 a b c d e 代表 1 ~ 9 不同的 5 个数字(注意是各不相同的数字,且不含 0 )

能满足形如: ab∗cde = adb∗ce 这样的算式一共有多少种呢?

请你利用计算机的优势寻找所有的可能,并回答不同算式的种类数。

满足乘法交换律的算式计为不同的种类,所以答案肯定是个偶数。

解题思路

根据题目要求,遍历所有数字组合,找到符合条件算式时,种类数+1即可。

解题代码:

代码语言:javascript
复制
public class 马虎的算式 {
	public static void main(String[] args){
		int count = 0;  //记录种类数
		//数字1~9随机,故遍历所有循环,abcde间的所有数字可能,则需要不断嵌套循环
		for(int a = 1;a < 10;++a) {
			for(int b = 1;b < 10;++b) {
				//循环前进行判断,保证是各不相同的数字
				if(a != b) for(int c = 1;c < 10;++c) {
					if(a != c && b!= c) for(int d = 1;d < 10;++d) {
						if(a != d && b != d && c != d) for(int e = 1;e < 10;++e) {
							if(a != e && b != e && c != e && d != e)
								//如果 ab∗cde = adb∗ce
							if((a*10 + b ) * (c*100+d*10+e) == (c*10 + e ) * (a*100+d*10+b))
								//数量+1
								++count;
						}
					}
				}
			}
		}
		System.out.print(count);
	}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 蓝桥杯真题--持续更新中...
  • 一、黄金连分数(填空)
  • 二、马虎的算式(填空)
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档