题目描述
方法
1. 数值遍历
class Solution:
def printNumbers(self, n: int) -> List[int]:
edge = int(math.pow(10,n))
list = []
for i in range(1, edge):
list.append(i)
return list
2. 考虑大数,字符串
class Solution:
def printNumbers(self, n: int) -> [int]:
def dfs(x):
if x == n:
s = ''.join(num[self.start:])
if s != '0': res.append(int(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 res