训练营第三十七天 | 738.单调递增的数字 ● 968.监控二叉树 ● 总结

文章讲述了如何使用Java代码实现将给定数字转换为单调递增的序列,并提及了监控二叉树的难题。通过遍历和字符数组操作,解决数字序列的调整问题,同时点出监控二叉树的复杂性。

738.单调递增的数字 

不会做

从后往前遍历,遇到不递增的情况,该位置数字减一,该位置之后的数字都为9,用start记录为9的位置

代码随想录

class Solution {
    public int monotoneIncreasingDigits(int n) {
        String s = String.valueOf(n);//将n转化为字符串
        char[] chars = s.toCharArray();//将字符串转化为字符数组
        int start = s.length();
        for(int i = s.length() - 2; i >= 0; i--) {
            if(chars[i] > chars[i+1]) {//不递增的话该位置数字减1,后面的都赋值9
                start = i+1;
                chars[i]--;
            }
        }
        for(int i = start; i < s.length(); i++) {
            chars[i] = '9';
        }
        return Integer.parseInt(String.valueOf(chars));
    }
}

 968.监控二叉树 (可以跳过)

不会做好难

代码随想录

 总结 

代码随想录

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值