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

蓝桥与力扣刷题(蓝桥 山)

题目:这天小明正在学数数。

他突然发现有些止整数的形状像一挫 “山”, 比㓚 123565321、145541123565321、145541, 它 们左右对称 (回文) 且数位上的数字先单调不减, 后单调不增。

小朋数了衣久也没有数完, 他惒让你告诉他在区间 [2022,2022222022] 中有 多少个数的形状像一座 “山”。

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

解题思路+代码:

代码:

public class 山{
    public static void main(String[] args) {
        int l = 2022, r = 2022222022; // 界定左右边界
        int ans = 0;

        // 遍历区间 [l, r] 的所有数
        for (long i = l; i <= r; i++) {
            if (check(i)) {
                ans++;
            }
        }
        System.out.println(ans); // 输出结果
    }

    // 回文检查方法
    public static boolean check(long num) {
        String str = Long.toString(num); //转化成字符串
        int n = str.length();
        //回文判定
        for (int i = 0; i < n / 2; i++) {
            if (str.charAt(i) != str.charAt(n - 1 - i)) {
                return false; // 如果不是回文数,返回false
            }
        }

        // 检查是否满足先单调不减,后单调不增的条件
        int i = 0;
        while (i < n - 1 && str.charAt(i) <= str.charAt(i + 1)) {
            i++;
        }
        while (i < n - 1 && str.charAt(i) >= str.charAt(i + 1)) {
            i++;
        }
        return i == n - 1; // 如果满足条件,返回true
    }
}

 总结:解答这道题最主要的是逻辑思维。首先解这道题需要掌握回文判定的相关知识创建判定传入的参数是否为回文的方法在遍历区间[2022,2022222022]的数时调用回文判定方法,是ans++。需要注意两个点:第一点:区间[2022,2022222022]的数很多,所以声明变量需要考虑所用的数据类型是否合适,加上在暴力枚举时会产生近20亿的数据量,所以在运行代码时花费的时间很长(我运行代码到出现结果大概30s到60s)。第二点:题目要求数位上的数字先单调不减, 后单调不增,这时就需要判断数是否满足该条件

相关文章:

  • Es6进阶
  • 递归、搜索、回溯算法
  • Linux平台x86_64|aarch64架构RTSP|RTMP直播播放器开发实践
  • 分布式并发控制实战手册:从Redis锁到ZK选主的架构之道
  • 群体智能优化算法-大猩猩部落优化算法(Gorilla Troops Optimizer, GTO,含Matlab源代码)
  • 【深度学习】
  • 基于Qwen2.5-7B-Instruct进行LoRA微调推理全流程探索
  • JavaScript基础-定时器
  • sock文件介绍--以mysql.sock为例
  • Spring AI + DeepSeek 构建大模型应用 Demo
  • 【HCIA-网工探长】09:OSPF快速配置的方法
  • 【弹性计算】异构计算云服务和 AI 加速器(四):FPGA 虚拟化技术
  • 《Python实战进阶》No37: 强化学习入门:Q-Learning 与 DQN-加餐版1 Q-Learning算法可视化
  • 十七天-Numpy 学习笔记
  • 无机械部件+线性频响:XARION传感器如何解决传统声学检测三大痛点?
  • VMware安装Ubuntu实战分享:从下载到桌面的完整指南
  • 【leetcode hot 100 347】前 K 个高频元素
  • 夯实 kafka 系列|第六章:自定义注解 @EvalEventListener 开发
  • Java-servlet(九)前端会话,会话管理与Cookie和HttpSession全解析
  • LeetCode 2829.k-avoiding 数组的最小总和:贪心(数学公式O(1)算出)
  • 网站跳出/河北网络科技有限公司
  • 肥城网站建设/企业网络营销策划案例
  • 福建微网站建设价格/国内免费二级域名建站
  • iis7 部署静态网站/seo外贸公司推广
  • 开发电子商务网站的主流语言/石家庄网站建设培训
  • 济南便宜网站设计/淘宝店怎么运营和推广