剑指offer 17 - 打印从1到最大的n位数 - Pyhon

178 阅读1分钟

题目描述

输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数 999。

示例 1:

输入: n = 1
输出: [1,2,3,4,5,6,7,8,9]

说明:用返回一个整数列表来代替打印,n 为正整数


题目要求顺序打印从1到位数为n的最大值,而最大值的下一个数必然是1后面跟n个0,这样题目就很容易了,直接写代码:

class Solution:
    def printNumbers(self, n: int) -> List[int]:
        s = int('1' + '0' * n)
        r = []
        for i in range(1, s):
            r.append(i)

        return r

或者可以简写成:

class Solution:
    def printNumbers(self, n: int) -> List[int]:
    
        return [i for i in range(1, int('1' + '0' * n))]