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

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

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
相关推荐
何双新40 分钟前
第21讲、Odoo 18 配置机制详解
linux·python·开源
Wish3D43 分钟前
阿里云OSS 上传文件 Python版本
开发语言·python·阿里云
阿福不是狗3 小时前
Python使用总结之Mac安装docker并配置wechaty
python·macos·docker
gen_3 小时前
mac环境下的python、pycharm和pip安装使用
python·macos·pycharm
AI视觉网奇3 小时前
pycharm 左右箭头 最近编辑
ide·python·pycharm
思绪无限3 小时前
Pycharm的终端无法使用Anaconda命令行问题详细解决教程
ide·python·pycharm·终端·命令行·anaconda·问题教程
漫步云端-r3 小时前
Pycharm的使用技巧总结
ide·python·pycharm
木子.李3475 小时前
排序算法总结(C++)
c++·算法·排序算法
风逸hhh5 小时前
python打卡day46@浙大疏锦行
开发语言·python
火兮明兮5 小时前
Python训练第四十三天
开发语言·python