动态规划——数位统计dp

acwing338.计数问题

cpp 复制代码
#include<iostream>
#include<cmath>

using namespace std;

int a, b;

int count(int n, int x) //统计从1到n中x的个数
{
    int res = 0;
    int l, r;
    int cnt = 0;
    int m = n;
    
    while(m)
    {
        cnt ++ ; //存储数字n的位数
        m /= 10;
    }
    
    for(int i = 1; i <= cnt; i ++ )
    {
        //以abcdefg为例来看,现在是计算第四位上x的次数,那么现在i=4

        //先计算最高三位为000~abc-1的情况
        r = pow(10, i - 1); //d右边可取到000~999共power10(i-1)个数
        l = n / (r * 10); //d左边可取到000~abc-1共abc种情况,if(x==0)则为001~abc-1共abc-1种
        //abc=n/power10(i)=n/(r*10);

        
        if(x) res += l * r;
        else res += (l - 1) * r;
        
        int d = (n / r) % 10; // n/r=abcd;abcd%10=d;
        //再计算高三位等于abc的情况(只需考虑d>=x,因为d<x就不符合条件)
        if(d == x) res += n % r + 1; //前四位abcd均相同,后三位可取0~efg共efg+1种,efg+1=n%power(i-1)+1=n%r+1;
        else if(d > x) res += r; //此时后三位可取000~999共power10(i-1)种
    }
    return res;
}

int main()
{
    while(cin >> a >> b, a || b)
    {
        if(a > b) swap(a, b);
        
        for(int i = 0; i < 10; i ++ )
            cout << count(b, i) - count(a - 1, i) << " ";
        
        cout << endl;    
    }
    return 0;
}
相关推荐
有为少年1 小时前
告别“唯语料论”:用合成抽象数据为大模型开智
人工智能·深度学习·神经网络·算法·机器学习·大模型·预训练
比昨天多敲两行1 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4501 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
Tisfy1 小时前
LeetCode 2839.判断通过操作能否让字符串相等 I:if-else(两两判断)
算法·leetcode·字符串·题解
问好眼1 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
会编程的土豆2 小时前
【数据结构与算法】优先队列
数据结构·算法
minji...3 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
罗湖老棍子4 小时前
最大数(信息学奥赛一本通- P1549)(洛谷-P1198)
数据结构·算法·线段树·单点修改 区间求最大值
小O的算法实验室5 小时前
2026年KBS,赏金猎人优化算法+多无人机移动边缘计算与路径规划,深度解析+性能实测
算法·无人机·边缘计算
用户5671504710215 小时前
OpenClaw 记忆管理系统技术文档
算法