题目描述
输入数字 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))]