LeetCode 357. Count Numbers with Unique Digits
Created at 20171103 Updated at 20171107 Category LeetCode
Question
Given a nonnegative integer n, count all numbers with unique digits, x, where 0 <= x < 10^n.
Example:
Given n = 2, return 91. (The answer should be the total numbers in the range of 0 <= x < 100, excluding [11,22,33,44,55,66,77,88,99])
Credits:
Special thanks to @memoryless for adding this problem and creating all test cases.
Solution
Here both dynamic programming and backtracking are good methods to tackle this problem, I will explain the detailed solution behind DP.
If you have learnt combination in mathmatics you will know that bascically this problem is a kind of combination problem, and here we go.
Since duplicated digits are not allowed in a number, and the leading zero is a nasty situation, we can count the number by the length of the number. For example, given n=3, and we get x between 0 and 999, so the length of a number in this range may be len=1, 2 or 3. Let us count the total number of all the numbers in this range.
Firstly, when len=1, apparently, the number is 10, that is result=10
And when len=2, since the highest digit is 0, and the the result=9*9, the first nine means there are 9 choices except for 0, and the second nine means there are 9 choices except for the number chosed in the previous digit.
And when len=2, there is no doubt that there are 99 result in the first 2 digits and for the last digit, since normally there are 10 choices, however 2 choices should be excluded and there are 8 choices. So the result=99*8.
In sum, the answer is 10+99+99*8=739.
To sum up,
when i==2, count=9*(10(i1)).
when i==3, count=9*9*(10(i1)).
…
when i==10, count=9*9*8..*(10(i1))
the maximum value of n is 10.
Accepted Code

