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

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

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
相关推荐
站大爷IP16 分钟前
Python多线程与多进程性能对比:从原理到实战的深度解析
python
j_xxx404_22 分钟前
数据结构:单链表的应用(力扣算法题)第一章
c语言·数据结构·算法·leetcode
东方佑25 分钟前
Python音频分析与线性回归:探索声音中的数学之美
python·音视频·线性回归
百度Geek说34 分钟前
ERNIE-4.5-VL:技术解密+应用实战,解锁多模态新场景!
算法
爱学习的小道长2 小时前
Python 比较huggingface_hub库的hf_hub_download函数和snapshot_download函数
开发语言·python
cur1es2 小时前
数据结构Java--8
java·数据结构·算法·散列表
tainshuai2 小时前
朴素贝叶斯:用 “概率思维” 解决分类问题的经典算法
算法·分类·数据挖掘
传奇开心果编程2 小时前
【传奇开心果系列】Flet框架实现的图形化界面的PDF转word转换器办公小工具自定义模板
前端·python·学习·ui·前端框架·pdf·word
竹子_232 小时前
《零基础入门AI: 目标检测基础知识》
人工智能·python·目标检测·计算机视觉