算法题:单调递增的数字(贪心算法解决序列问题)

这道题参考了一位网友的思路,采用了贪心算法+动态规划,具体思路如下:(完整题目附在了最后面)

1、从高到低遍历数字的每个位数,找到第一个数值递减(<)的地方,把当前位-1,后面的位全部置为9。

2、重复步骤1数次,直到数字位数从高到低的数值呈现递增(>=),就得到了我们要的结果。

代码如下:

复制代码
class Solution(object):

    def dp(self, nums):
        for i in range(len(nums) - 1):
            if nums[i + 1] < nums[i]:
                nums[i] = str(int(nums[i]) - 1)
                for j in range(i + 1, len(nums)):
                    nums[j] = '9'
                return self.dp(nums)
        return nums

    def monotoneIncreasingDigits(self, n):
        n = list(str(n))
        return int(''.join(self.dp(n)))

if __name__ == '__main__':
    sol = Solution()
    print(sol.monotoneIncreasingDigits(1234321))
    # print(sol.monotoneIncreasingDigits(10))

完整题目:

738. 单调递增的数字

当且仅当每个相邻位数上的数字 xy 满足 x <= y 时,我们称这个整数是单调递增的。

给定一个整数 n ,返回 小于或等于 n 的最大数字,且数字呈 单调递增

示例 1:

复制代码
输入: n = 10
输出: 9

示例 2:

复制代码
输入: n = 1234
输出: 1234

示例 3:

复制代码
输入: n = 332
输出: 299

提示:

  • 0 <= n <= 10^9
相关推荐
天天进步201530 分钟前
Python项目-基于Flask的个人博客系统设计与实现(1)
开发语言·python·flask
安然无虞32 分钟前
31天Python入门——第20天:魔法方法详解
开发语言·后端·爬虫·python
靠近彗星43 分钟前
基于 Vue + Django + MySQL 实现个人博客/CMS系统
前端·vue.js·python·mysql·django
励志成为大佬的小杨1 小时前
pytorch模型的进阶训练和性能优化
人工智能·pytorch·python
舔甜歌姬的EGUMI LEGACY1 小时前
【算法day28】解数独——编写一个程序,通过填充空格来解决数独问题
算法
welkin1 小时前
KMP 个人理解
前端·算法
半桔1 小时前
红黑树剖析
c语言·开发语言·数据结构·c++·后端·算法
eason_fan2 小时前
前端面试手撕代码(字节)
前端·算法·面试
今天_也很困2 小时前
牛客2025年愚人节比赛
c++·算法
Joe_Wang52 小时前
[图论]拓扑排序
数据结构·c++·算法·leetcode·图论·拓扑排序