Skip to content

386. Lexicographical Numbers

Difficulty: Medium

LeetCode Problem View on GitHub


386. Lexicographical Numbers

Medium


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:

Input: n = 13
Output: [1,10,11,12,13,2,3,4,5,6,7,8,9]

Example 2:

Input: n = 2
Output: [1,2]

 

Constraints:

  • 1 <= n <= 5 * 104

Solution

class Solution {
    public List<Integer> lexicalOrder(int n) {
        List<Integer> res = new ArrayList<>(n);
        int current = 1;
        for (int i = 0; i < n; i++) {
            res.add(current);
            if (current * 10 <= n) current *= 10;
            else {
                while (current % 10 == 9 || current + 1 > n)  current /= 10;
                current++;
            }
        }
        return res;
    }
}

Complexity Analysis

  • Time Complexity: O(?)
  • Space Complexity: O(?)

Approach

Detailed explanation of the approach will be added here