当前位置: 首页 > article >正文

蓝桥杯 - 每日打卡(类斐波那契循环数)

题目:

在这里插入图片描述

解题思路:

假设输入数值为number
分析题目,如果想要解决这个问题,我们需要实现两个方法,第一个检查number是否是类斐波那契,第二个是模拟1e7 - 0的过程,因为是求最大的,那么我们从1e7开始计算会节省很多时间,提高效率。
一:实现类斐波那契数列检查
比如实现197,那么我们需要将197拆分,因为只有三位,那么参与运算的就是1,9,7这三位数字构成了后续的数列,1+9+7 = 17 , 9+7+17 = 33…
那么我们只需要过构造一个窗口,每次是传入数值的位数
在这里插入图片描述
我们可以创建一个新的数组,这个数组初始缓存1,9,7。然后窗口大小是传输 数字的位数,此时 a4 = a1+a2+a3 ,然后窗口移动,直到计算出 an == number 返回 true,如果an > number 那么就应该结束

代码:

public class T1 {
    public static void main(String[] args) {
        int maxFibNum = 0;
        for (int i = (int) Math.pow(10, 7); i >= 0; i--) {
            if (check(i)) {
                maxFibNum = i;
                break;
            }
        }
        System.out.println("最大的类斐波那契循环数:" + maxFibNum);
    }

    public static boolean check(int num) {
        if (num == 0) return true;

        int[] arr = new int[10];
        int len = 0;
        int temp = num;
        while (temp > 0) {
            arr[len++] = temp % 10;
            temp /= 10;
        }

        int[] digits = new int[len];
        for (int i = 0; i < len; i++) {
            digits[i] = arr[len - 1 - i];
        }
//        构造的新的队列
//        为什么构造这个100,这个需要你尝试从小到大,如果100 和 500 结果一样,那么就证明这个数值设置的合理
        int[] newArray = new int[100];
        System.arraycopy(digits, 0, newArray, 0, len);
        int index = len;
        while (true) {
            int sum = 0;
//            从 0 - 数字位数 , 计算下一位
            for (int i = index - len; i < index; i++) {
                sum += newArray[i];
            }
            if (sum > num) break;
            if (sum == num) return true;
//            窗口后移
            newArray[index++] = sum;
        }
        return false;
    }
}
// 7913837

http://www.kler.cn/a/570644.html

相关文章:

  • 国产编辑器EverEdit - 超多样式设置
  • 深入解析 Rust 异步编程中的 Traits
  • 计算机毕业设计SpringBoot+Vue.js医院后台管理系统(源码+文档+PPT+讲解)
  • 【Elasticsearch】Data Streams
  • 03 HarmonyOS Next仪表盘案例详解(二):进阶篇
  • 【三.大模型实战应用篇】【6.自然语言转SQL:AI与数据库的无缝对接】
  • doris: Hive Catalog
  • 基于提示驱动的潜在领域泛化的医学图像分类方法(Python实现代码和数据分析)
  • unity pico开发 五 UI交互
  • io学习----->标准io
  • 【2025年2月28日稳定版】小米路由器4C刷机Immortalwrt 23.05.4系统搭载mentohust 0.3.1插件全记录
  • java中代理模式 之 静态代理模式
  • 2025GDC全球开发者大会 | 函子科技现场演示DeepSeek+OpenAI协同调用,手把手传授无代码+AI变现方案
  • SFP28(25 Gigabit Small Form-factor Pluggable)详解
  • C++(蓝桥杯常考点)
  • 开源嵌入式实时操作系统NuttX介绍
  • 【Java数据结构】Map Set
  • 【前端】HTML 备忘清单(超级详细!)
  • 《一个端粒到端粒的参考基因组为木瓜中五环三萜类化合物生物合成提供了遗传学见解》
  • 大语言模型学习--本地部署DeepSeek