算法Day26 数位统计

数位统计

Description

给你一个整数n,统计并返回各位数字都不同的数字x的个数,其中0 ≤ x < 10^n。

Input

输入整数n

0≤n≤13

Output

输出整数个数

Sample

代码

java 复制代码
import java.util.Scanner;

public class Main {

    public static void main(String[] args) {

        Scanner in = new Scanner(System.in);
        int k = in.nextInt();
        System.out.println(countNumber(k));
    }
    public static int countNumber(int n){
        int dp[] = new int[11];
        dp[0] = 1;
        dp[1] = 9;
        for(int i=2;i<=10;i++){
            dp[i] = (10-i+1)*dp[i-1];
        }
        int sum = 0;
        if(n<=10){
            for(int i =0;i<=n;i++){
                sum+=dp[i];
            }
        }else {
            for(int i =0;i<=10;i++){
                sum+=dp[i];
            }
        }
        return sum;

    }

}

思路

题目给的范围是0-13,但是大于10的时候,已经不存在每个位数上数字不相等的情况了

因此仍是0-10的动态规划问题
i长度的符合数字是i-1长度的符合数字的(10-i+1)倍数量

相关推荐
Zhang~Ling42 分钟前
C++ 红黑树封装:myset和mymap的底层实现
开发语言·数据结构·c++·算法
ECT-OS-JiuHuaShan43 分钟前
什么是对和错?——“有针对性定义域的逻辑值的真伪”:认识论终极追问的公理化裁决
数据库·人工智能·算法·机器学习·数学建模
Merlyn101 小时前
【栈】155. 最小栈
python·算法
一个不知名程序员www1 小时前
算法学习入门---算法题DAY5
c++·算法
San813_LDD1 小时前
[量化]《虚函数调用时间复杂度完全解析:为什么是 O(1) 以及它的真实代价》
java·数据结构·算法
MartinYeung51 小时前
[论文学习]利用索引梯度优化基于优化的 LLM 越狱攻击:MAGIC 方法的深度分析与实现
人工智能·学习·算法
数据仓库搬砖人2 小时前
特征选择三剑客:前向、后向、全子集,哪种更适合你?
算法
起个破名想半天了2 小时前
算法与数据结构之Floyd算法
数据结构·算法
千寻girling2 小时前
机器学习 | 无监督学习算法(了解) | 尚硅谷学习
学习·算法·机器学习
小七在进步2 小时前
数据结构:线性表之顺序表
c语言·数据结构·算法