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

相关推荐
IUGEI32 分钟前
从原理到落地:DAG在大数据SLA中的应用
java·大数据·数据结构·后端·算法
云深麋鹿34 分钟前
五.排序笔记
c语言·数据结构·算法·排序算法
spcier7 小时前
图论拓扑排序-Kahn 算法
算法·图论
知星小度S7 小时前
动态规划(一)——思想入门
算法·动态规划
ysa0510307 小时前
动态规划-逆向
c++·笔记·算法
燃于AC之乐7 小时前
我的算法修炼之路--7—— 手撕多重背包、贪心+差分,DFS,从数学建模到路径DP
c++·算法·数学建模·深度优先·动态规划(多重背包)·贪心 + 差分
chinesegf7 小时前
文本嵌入模型的比较(一)
人工智能·算法·机器学习
We་ct8 小时前
LeetCode 6. Z 字形变换:两种解法深度解析与优化
前端·算法·leetcode·typescript
REDcker8 小时前
Redis容灾策略与哈希槽算法详解
redis·算法·哈希算法
福楠8 小时前
C++ STL | map、multimap
c语言·开发语言·数据结构·c++·算法