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

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

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
相关推荐
成成成成成成果1 分钟前
揭秘动态测试:软件质量的实战防线
python·功能测试·测试工具·测试用例·可用性测试
技术思考者32 分钟前
Leetcode - 反转字符串
数据结构·算法·leetcode
天天进步201541 分钟前
Python游戏开发引擎设计与实现
开发语言·python·pygame
数据狐(DataFox)1 小时前
CTE公用表表达式的可读性与性能优化
经验分享·python·sql
蹦蹦跳跳真可爱5891 小时前
Python----MCP(MCP 简介、uv工具、创建MCP流程、MCP客户端接入Qwen、MCP客户端接入vLLM)
开发语言·人工智能·python·语言模型
SKYDROID云卓小助手1 小时前
无人设备遥控器之多设备协同技术篇
网络·人工智能·嵌入式硬件·算法·信号处理
No0d1es1 小时前
第13届蓝桥杯Python青少组中/高级组选拔赛(STEMA)2022年1月22日真题
python·青少年编程·蓝桥杯·选拔赛
MediaTea2 小时前
Python 库手册:getopt Unix 风格参数解析模块
服务器·开发语言·python·unix
王尼莫啊2 小时前
【立体标定】圆形标定板标定python实现
开发语言·python·opencv
熬了夜的程序员2 小时前
【华为机试】34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·华为od·华为·面试·golang