您当前的位置: 首页 >  leetcode

孑渡

暂无认证

  • 3浏览

    0关注

    178博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

【Leetcode】剑指Offer 17:打印从1到最大的n位数

孑渡 发布时间:2022-09-07 08:45:37 ,浏览量:3

输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数 999。 示例 1: 输入: n = 1 输出: [1,2,3,4,5,6,7,8,9] 说明: 用返回一个整数列表来代替打印 n 为正整数 来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/da-yin-cong-1dao-zui-da-de-nwei-shu-lcof 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

AC代码
class Solution:
    def printNumbers(self, n: int) -> List[int]:
        return [i for i in range(1, 10 ** n)]

唔。。有些水得不像话了,甚至不能领悟到考点是什么。看了评论才明白重点在于int类型的大数限制,需要考虑范围。那问题本质上就转变为了打印字符串了,利用简单的dfs遍历再考虑去掉最开头的0即可得到结果。

大数限制解法
class Solution:
    def printNumbers(self, n: int) -> [int]:
        def dfs(x):
            if x == n:
                s = ''.join(num[self.start:])
                if s != '0': res.append(s)
                if n - self.start == self.nine: self.start -= 1
                return
            for i in range(10):
                if i == 9: self.nine += 1
                num[x] = str(i)
                dfs(x + 1)
            self.nine -= 1
        
        num, res = ['0'] * n, []
        self.nine = 0
        self.start = n - 1
        dfs(0)
        return ','.join(res)

额外可以学习在这里出现的str.join()方法,可以将一个列表拼起来作为字符串输出。

关注
打赏
1663211900
查看更多评论
立即登录/注册

微信扫码登录

0.0389s