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

2024年蓝桥杯Java B组省赛真题超详解析-类斐波那契循环数

要求:请问在0至1e7中,最大的类斐波那契循环数是多少

问题:判断一个数是否是类斐波那契数(重点)

问题:判断一个数是否是类斐波那契数(重点)

一、描述1:对于一个有n位的十进制数N=d1d2d3…dn

  • 将给定数字转为分解成单个数字:toList 方法
  1. 将数字 ( a ) 的每一位提取出来,存储到一个列表中,从高位到低位排列。
  2. 示例:197 -> [1, 9, 7]。
  3. 用于初始化类斐波那契数列的起始部分。

二、描述2:如果这个数N会出现在对应的类斐波那契数列S中,那么N就是一个类斐波那契循环数

(二)判断是否为循环数:isFab 方法

  1. 初始化类斐波那契数列的起始部分为 a 的各位数。
  2. 持续递推生成新数(类斐波那契数列的下一个数字为前 ( len ) 个数的和),并检查:
  3. 若生成的数字等于 ( a ),则 ( a ) 是循环数,返回 true。
  4. 若生成的数字大于 ( a ),则 ( a ) 不是循环数,返回 false。

要求:请问在0至1e7中,最大的类斐波那契循环数是多少

三、寻找最大循环数

  1. 从 ( 10^7 ) 开始向下遍历,逐个判断是否为循环数。
  2. 遇到第一个循环数时,直接输出并终止程序。

import java.util.*;
public class Main1 {
    //获取起始序列
    static List<Integer> toList(int a){
        List<Integer> list=new ArrayList<>();
        while(a>0){
            int t=a%10;//得到个位数
            list.add(t);
            a/=10;
        }
        Collections.reverse(list);//逆置
        return list;
    }

    //判断是否是循环数
    static boolean isFab(int a){
            ArrayList<Integer> list=new ArrayList<>(toList(a));
            int len=list.size();//获得a的位数
            while(true){
                int sum=0;
                //注意下标不要越界!!!
                for(int i=list.size()-1;i>list.size()-1-len;i--){//递推类斐波那契数
                    sum+=list.get(i);
                }
                if(sum==a)return true;
                if(sum>a)return false;
                list.add(sum);
            }
    }

    public static void main(String[] args) {
            int end=(int)1e7;
            while(end>0){
                if(isFab(end)){
                    System.out.println(end);
                    return;
                }
                end--;
            }
    }
}

相关文章:

  • 数据结构:链表 (C++实现)
  • 最短路径问题
  • Selenium 元素定位方法详解
  • 在WSL中高效使用Windows目录下的Ollama模型
  • 如何在最新的 Mac mini M4 机器上,让 Ollama 支持局域网访问
  • 91%准确率预测耀斑!国家天文台推出太阳大模型“金乌”,推动天文研究进入AI时代
  • ngx_open_file
  • 通义万相环境搭建推理测试
  • 深度学习deeplearn1
  • Linux命令-sort
  • 如何申请p12证书
  • 【Kafka基础】解析Kafka核心特性:高吞吐、持久化与高可用架构
  • 关于终端安全管理系统在社会工作中的重要作用
  • FastAPI与ASGI深度整合实战指南
  • 使用Redis构架你自己的私有大模型
  • 嘎嘎棒,ethernet ip转profinet网关锁鲜食品加工业
  • 安装electron项目是为什么要执行postinstall script
  • Dubbo(30)如何配置Dubbo的服务分片?
  • linux0.11内核源码修仙传第十三章——进程调度大战前夕
  • AIO,BIO,NIO的区别(详解)
  • 首都产业建设集团网站/网站关键词优化推广哪家好
  • win2003建网站/百度广告一级代理
  • 政府门户网站建设策划/2023年百度小说风云榜
  • 绵阳公司网站制作公司/新乡网络推广外包
  • 如何做微信小程序网站/网站注册查询
  • 品牌策划公司名字大全/手机百度seo快速排名