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

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

他突然发现有些止整数的形状像一挫 “山”, 比㓚 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)。第二点:题目要求数位上的数字先单调不减, 后单调不增,这时就需要判断数是否满足该条件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

এ旧栎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值