算法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)倍数量

相关推荐
浅念-4 小时前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
做cv的小昊5 小时前
【TJU】研究生应用统计学课程笔记(8)——第四章 线性模型(4.1 一元线性回归分析)
笔记·线性代数·算法·数学建模·回归·线性回归·概率论
贾斯汀玛尔斯5 小时前
每天学一个算法--倒排索引(Inverted Index)
算法·inverted-index
小e说说5 小时前
打破偏科困境:这些学习软件助孩子重燃学习热情
算法
月昤昽6 小时前
autoCAD二次开发 4.正多边形与collection区分
算法·c#·二次开发·autocad二次开发
休息一下接着来6 小时前
C++ 固定容量环形队列实现
c++·算法
im_AMBER6 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵
笨笨饿7 小时前
#79_NOP()嵌入式C语言中内联汇编宏的抽象封装模式研究
linux·c语言·网络·驱动开发·算法·硬件工程·个人开发
风萧萧19997 小时前
问答样例如何在RAG问答中使用?
算法