357. Count Numbers with Unique D

2017-07-30  本文已影响0人  这就是一个随意的名字

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,要求在0到10^n的范围内(左闭右开),统计所有各位不相同的数字的个数。


思路
设f(n)为恰好为n位数时所有各位数字均不同的数字个数。根据排列组合的原理,容易得到以下规律:

而题目中要求的是返回0到10^n之中所有的满足条件的数字个数,所以最后的结果res应该是:

class Solution {
public:
    int countNumbersWithUniqueDigits(int n) {
        vector<int> res(11);
        res[0]=1;
        res[1]=10;
        res[2]=9*9;
        for(int i=3;i<res.size();i++){
            res[i]=res[i-1]*(10-i+1);
        }
        for(int i=2;i<res.size();i++){
            res[i]+=res[i-1];
        }
        if(n<=0) return res[0];
        else if(n>10) return res[10];
        else return res[n];
    }
};
上一篇下一篇

猜你喜欢

热点阅读