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

相关推荐
谷雨不太卷10 小时前
进程的状态码
java·前端·算法
散峰而望11 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德11 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya11 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦11 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
挽星安11 小时前
代码随想录算法训练营第五十天|卡码网 99 岛屿数量、卡码网 100 最大岛屿的面积
算法
葫三生11 小时前
《论三生原理》系列构建文理同构的认知体系?
人工智能·科技·深度学习·算法·机器学习·transformer
多加点辣也没关系12 小时前
数据结构与算法|第六章:队列
数据结构·算法·队列
_深海凉_12 小时前
LeetCode热题100-分割回文串
算法·leetcode·职场和发展