Post

386 Lexicographical Numbers

386 Lexicographical Numbers

Lexicographical Numbers image

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.