386 Lexicographical Numbers
386 Lexicographical Numbers
Lexicographical Numbers 
Given an integer n, return all the numbers in the range [1, n] sorted in lexicographical order.
You must write an algorithm that runs in O(n) time and uses O(1) extra space.
Example 1:
1
2
3
**Input:** n = 13
**Output:** [1,10,11,12,13,2,3,4,5,6,7,8,9]
Example 2:
1
2
3
**Input:** n = 2
**Output:** [1,2]
Constraints:
1
1 <= n <= 5 * 104
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
class Solution:
def lexicalOrder(self, n: int) -> List[int]:
def recurse(m):
if m > n :
return
res = [m]
for i in range(0,10):
t = recurse(m * (10) + i)
if t != None:
res += t
return res
a = []
for m in range(1,10):
l = recurse(m)
if l != None:
a += l
return a
This post is licensed under CC BY 4.0 by the author.