Create 357. Count Numbers with Unique Digits.md

This commit is contained in:
ShusenTang 2019-12-12 21:14:22 +08:00 committed by GitHub
parent 2adb057f3f
commit 276e4101ea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -0,0 +1,43 @@
# [357. Count Numbers with Unique Digits](https://leetcode.com/problems/count-numbers-with-unique-digits/)
# 思路一
给定一个整数n求范围[0,10^n]内有多少个各位上不均相同的数字例如134这种。
这其实就是个数学题我们考虑一下如何构造一个共i位且各位各不相同的数
* 先从0-9这10个数字中选取i个数字;
* 再将选取的i个数字进行排列需注意0不能排在最前面
由高中数学排列组合知识知从10个数选取i个再排列一共有A(10,i)种情况再除去0排在前面的共A(9,i),所以最后一共有 A(10,i) - A(9,i) = 9*A(9, i-1)。
> A(m, n) = m * (m-1) * ... * (m-n+1)
需要注意的是如果位数超过10那就没法组成每位都不相同的数了。
知道通项公式后我们就可以根据n的大小把[1, n]区间位数通过通项公式算出来累加起来即可。
如果没想到数学解法,本题也可以直接进行搜索。
# C++
``` C++
// 此代码还可优化, 算阶乘那里重复计算了
class Solution {
private:
int helper(int n){
if(n == 0) return 1;
if(n > 10) return 0;
int res = 9;
for(int i = 9; i > 9 - n + 1; i--)
res *= i;
return res;
}
public:
int countNumbersWithUniqueDigits(int n) {
int res = 0;
for(int i = 0; i <= n; i++)
res += helper(i);
return res;
}
};
```