前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日算法系列【LeetCode 357】计算各个位数不同的数字个数

每日算法系列【LeetCode 357】计算各个位数不同的数字个数

作者头像
godweiyang
发布2020-03-24 10:40:00
8150
发布2020-03-24 10:40:00
举报
文章被收录于专栏:算法码上来

题目描述

给定一个非负整数 n ,计算各位数字都不同的数字 x 的个数,其中 。

示例1

代码语言:javascript
复制
输入:
2
输出:
91
解释:
答案应为除去 11,22,33,44,55,66,77,88,99 外,在 [0,100) 区间内的所有数字。

题解

这题要求所有数位数字都不相同的数字个数,那么我们可以将答案分成不同长度。

方法1

对于长度为 n 的数字,第一位取值有 1~9 一共 9 种情况,而后面 n - 1 位可以从 0~9 中随机取出 n - 1 个不同数字,然后随机排列。因为要和第一位不同,所以后面的数字选择只有 9 种情况,所以方案数是排列数 。

然后一直累和到长度为 1 的数字,最后还有个特例,就是 0 ,它是首位可以为 0 的唯一情况。

所以最终答案就是 。具体实现的时候可以将阶乘预处理好,然后直接用就行了。

方法2

因为 n 不会太大,所以我们可以本地将每个 n 对应的答案算出来,然后保存到数组里,提交的时候直接取答案就行了。这种方法非常投机取巧,适合直接做会超时,但是答案数量又不是太多的情况。

代码

方法1(c++)

代码语言:javascript
复制
class Solution {
public:
    int countNumbersWithUniqueDigits(int n) {
       int fact[10] = {1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880};
       int res = 0;
       for (int i = 10-n; i <= 9; ++i) {
           res += fact[9] / fact[i];
       }
       return res * 9 + 1;
    }
};

方法1(python)

代码语言:javascript
复制
class Solution:
    def countNumbersWithUniqueDigits(self, n: int) -> int:
        fact = [1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880]
        res = 0
        for i in range(10-n, 10):
            res += int(fact[9] / fact[i])
        return res * 9 + 1

方法2(c++)

代码语言:javascript
复制
class Solution {
public:
    int countNumbersWithUniqueDigits(int n) {
       int res[] = {1, 10, 91, 739, 5275, 32491, 168571, 712891, 2345851, 5611771};
       return res[n];
    }
};

方法2(python)

代码语言:javascript
复制
class Solution:
    def countNumbersWithUniqueDigits(self, n: int) -> int:
        res = [1, 10, 91, 739, 5275, 32491, 168571, 712891, 2345851, 5611771]
        return res[n]

后记

这题还可以用递归、解出和式的通式等方法求解,本质上没有太大区别。

作者简介:godweiyang知乎同名华东师范大学计算机系硕士在读,方向自然语言处理与深度学习。喜欢与人分享技术与知识,期待与你的进一步交流~

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-01-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 算法码上来 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目描述
  • 题解
    • 方法1
      • 方法2
      • 代码
        • 方法1(c++)
          • 方法1(python)
            • 方法2(c++)
              • 方法2(python)
              • 后记
              相关产品与服务
              NLP 服务
              NLP 服务(Natural Language Process,NLP)深度整合了腾讯内部的 NLP 技术,提供多项智能文本处理和文本生成能力,包括词法分析、相似词召回、词相似度、句子相似度、文本润色、句子纠错、文本补全、句子生成等。满足各行业的文本智能需求。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档