Given a
non-negative 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]
)
思路:类似于排列组合的问题,求没有重复的数字的个数。当n=1时,0-9都是一位数,没有重复的数,则f(1)=10;当n>=2时,最高位只能是1-9
中的一位数,总共有9种可能,之后选择的数字要求与之前的不相同,则可以选择的数字依次减少,分别为9,8,7,...,则
f(k)=f(k-1)+9*9*8*....*(9-k+2);
代码如下:
public class Solution {
public int countNumbersWithUniqueDigits(int n) {
if(n==0)
return 1;
if(n==1)
return 10;
int val=9;
int ret=10;
for(int i=2;i<=n;i++){
val=val*(9-i+2);
ret=ret+val;
}
return ret;
}
}