博客
关于我
单调递增的数字
阅读量:409 次
发布时间:2019-03-06

本文共 767 字,大约阅读时间需要 2 分钟。

为了找到小于或等于给定整数N的最大整数,使其各个位数上的数字是单调递增的,我们可以从右到左遍历每一位数字,并在遇到不符合条件的情况时进行调整。

方法思路

  • 问题分析:我们需要找到一个最大的整数,使得它的每一位数字从左到右是单调递增的。例如,数字1323中的3大于2,不符合条件,因此需要调整为1299。
  • 遍历数字:将数字转换为字符串,从右到左遍历每一位。对于每一位,检查它是否大于前一位。如果是,调整当前位并将后面的所有位变为9。
  • 调整逻辑:如果当前位大于下一位,将当前位减一,并将后面的所有位变为9。这样可以确保数字的单调递增性。
  • 解决代码

    function monotoneIncreasingDigits(N) {    let s = N.toString();    for (let i = s.length - 2; i >= 0; i--) {        if (s[i] > s[i + 1]) {            s = s.substring(0, i) + (parseInt(s[i]) - 1).toString() + '9'.repeat(s.length - i - 1);        }    }    return parseInt(s);}

    代码解释

  • 转换为字符串:将整数N转换为字符串s,便于逐位处理。
  • 遍历每一位:从右到左遍历每一位,从第二位开始到第一位结束。
  • 检查递增性:比较当前位和前一位。如果当前位大于前一位,说明不符合单调递增的条件。
  • 调整数字:将当前位减一,并将后面的所有位变为9。例如,处理332时,调整为299。
  • 返回结果:将调整后的字符串转换回整数并返回。
  • 该方法确保了我们能够找到满足条件的最大整数,并且在遇到不符合条件的情况时进行调整,确保数字的单调递增性。

    转载地址:http://wlckz.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现数组的循环左移(附完整源码)
    查看>>
    Objective-C实现数除以二divideByTwo算法(附完整源码)
    查看>>
    Objective-C实现文件分割(附完整源码)
    查看>>
    Objective-C实现文件的删除、复制与重命名操作实例(附完整源码)
    查看>>
    Objective-C实现无序表查找算法(附完整源码)
    查看>>
    Objective-C实现无锁链表(附完整源码)
    查看>>
    Objective-C实现无锁链表(附完整源码)
    查看>>
    Objective-C实现时间戳转为年月日时分秒(附完整源码)
    查看>>
    Objective-C实现是否为 Pythagoreantriplet 毕氏三元数组算法(附完整源码)
    查看>>
    Objective-C实现显示响应算法(附完整源码)
    查看>>
    Objective-C实现晚捆绑测试实例(附完整源码)
    查看>>
    Objective-C实现普通矩阵A和B的乘积(附完整源码)
    查看>>
    Objective-C实现更新数字指定偏移量上的值updateBit算法(附完整源码)
    查看>>
    Objective-C实现最大类间方差法OTSU算法(附完整源码)
    查看>>
    Objective-C实现最大非相邻和算法(附完整源码)
    查看>>
    Objective-C实现最小二乘多项式曲线拟合(附完整源码)
    查看>>
    Objective-C实现最小路径和算法(附完整源码)
    查看>>
    Objective-C实现最快的归并排序算法(附完整源码)
    查看>>
    Objective-C实现最长公共子序列算法(附完整源码)
    查看>>
    Objective-C实现最长回文子串算法(附完整源码)
    查看>>