The Counting Problem
询问区间\([a,b]\)中\(1\sim 9\)出现的次数,0 < a, b < 100000000。
解
显然为数位递推,考虑试填法,现在关键是求出方案数,于是设\(A[i]\)表示i位以内数字中0出现的次数,不含前导0,\(B[i]\)为i位数字中\(0\sim 9\)出现的次数,可以含前导0,不难有(其中\(base[i]=10^i\)),显然有
\]
\]
边界:\(A[0]=B[0]=0\)
解释:对于\(B[i]\),显然与第i位填什么有关,只能填0~9(含前导0),i-1位能够统计的数字个数翻10倍,然后对于第i位填上该个数字,剩下的数字自由组合有\(base[i-1]\),对于\(A[i]\),i-1位以内方案\(A[i-1]\),i位的方案是\(9B[i-1]\)(只能填\(1\sim 9\))。
于是对于一个数位题目,当我们处理好含前导0i位数字方案(前面的数字已经填好统计方案)和不含前导0i位以内的方案(前面的数字没有填好,不允许含前导0)的方程时,该题基本完成一半,罗嗦几句,帮助理解,对于\(1\sim 9\)的数字而言只需要\(B[i]\)数组即可,因为含前导0有两重意思都是等价的,一是i位数字上的含前导0的数的数字出现次数,二是i位以内的不含前导0的数的出现的次数,而0没有这个特殊待遇,于是得在维护一个\(A[i]\),剩下的照数位递推套路进行即可。
参考代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#define il inline
#define ri register
#define ll long long
#define swap(x,y) x^=y^=x^=y
using namespace std;
int num[9];
ll A[9],B[9],base[9],at[10],bt[10];
il void prepare();
il void ask(int n,ll[]);
int main(){
int a,b;prepare();
while(scanf("%d%d",&a,&b),a&&b){
if(a>b)swap(a,b);
ask(a-1,at),ask(b,bt);
for(int i(0);i<10;++i)
printf("%lld ",bt[i]-at[i]);
putchar('\n');
}
return 0;
}
il void ask(int n,ll ans[]){++n,num[0]&=0;
do num[++num[0]]=n%10,n/=10;while(n);
ans[0]=0;
for(int j(num[0]),k,l(0);j;--j){
for(k=0;k<num[j];++k)
ans[0]+=A[j-1]+base[j-1]*(l+!k);
if(!num[j])++l;
}ans[0]+=B[num[0]-1],ans[0]-=A[num[0]-1]+base[num[0]-1];
if(num[0]==1)++ans[0];
for(int i(1),j,k,l;i<10;++i)
for(j=num[0],l=ans[i]=0;j;--j){
for(k=0;k<num[j];++k){
ans[i]+=A[j-1]+base[j-1]*(l+(k==i));
}if(num[j]==i)++l;
}
}
il void prepare(){base[0]=1;
for(int i(1);i<9;++i)
base[i]=base[i-1]*10,A[i]=A[i-1]*10+base[i-1];B[1]=1;
for(int i(2);i<9;++i)B[i]=9*A[i-1]+B[i-1];
}
The Counting Problem的更多相关文章
- UVA 1640 The Counting Problem UVA1640 求[a,b]或者[b,a]区间内0~9在里面各个数的数位上出现的总次数。
/** 题目:UVA 1640 The Counting Problem UVA1640 链接:https://vjudge.net/problem/UVA-1640 题意:求[a,b]或者[b,a] ...
- 『The Counting Problem 数位dp』
The Counting Problem Description 求 [L,R]内每个数码出现的次数. Input Format 若干行,一行两个正整数 L 和 R. 最后一行 L=R=0,表示输入结 ...
- POJ2282 The Counting Problem
题意 Language:DefaultEspañol The Counting Problem Time Limit: 3000MS Memory Limit: 65536K Total Submis ...
- UVa 1640 - The Counting Problem(数论)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA 1640 The Counting Problem
https://vjudge.net/problem/UVA-1640 题意:统计区间[l,r]中0——9的出现次数 数位DP 注意删除前导0 #include<cmath> #inclu ...
- [POJ 2282] The Counting Problem
[题目链接] http://poj.org/problem?id=2282 [算法] 数位DP [代码] #include <algorithm> #include <bitset& ...
- POJ2282:The Counting Problem(数位DP)
Description Given two integers a and b, we write the numbers between a and b, inclusive, in a list. ...
- UVa 1640 (计数) The Counting Problem
题意: 统计[a, b]或[b, a]中0~9这些数字各出现多少次. 分析: 这道题可以和UVa 11361比较来看. 同样是利用这样一个“模板”,进行区间的分块,加速运算. 因为这里没有前导0,所以 ...
- UVa 1640 The Counting Problem (数学,区间计数)
题意:给定两个数m, n,求从 m 到 n 中0-9数字各出现了多少次. 析:看起来挺简单的,其实并不好做,因为有容易想乱了.主要思路应该是这样的,分区间计数,先从个位进行计,一步一步的计算过来.都从 ...
随机推荐
- JDK8新特性之函数式接口
什么是函数式接口 先来看看传统的创建线程是怎么写的 Thread t1 = new Thread(new Runnable() { @Override public void run() { Syst ...
- windows平板软件开机自启动+霸屏的操作方法
转载(忘了地址) 很好很强大.成功亲测 使用你自己的账号(最好是管理员权限的账号)登录Windows,然后添加一个给其他人使用的账户(假设为other),注意一定要为other设置密码. 运行 ...
- 前端 css 补充内容
给个菜鸟教程的css教程网址(全的狠!!!): https://www.runoob.com/css/css-tutorial.html 下面是几张css基础样式图:
- Center OS 7安装 Apollo
声明: 每个人的情况都不一样,所以大家在看教程的时候自行斟酌,最好先扫一遍,再来根据自身情况进行操作.同时,遇到的问题也可能不尽相同,要灵活处理. 了解: Apollo是从原始ActiveMQ的基础构 ...
- WordTEX
https://www.andrew.cmu.edu/user/twildenh/wordtex/
- Servlet 上传图片
目录 Servlet 上传图片 预备 需求包 pom 前端代码 Servlet 上传图片 预备 需求包 commons-fileupload -用于上传 jstl -用于jsp页面遍历 servlet ...
- MetalLB自建私有Kubernetes的LoadBalancer负载均衡类型服务
简介 在私有网络上运行 Kubernetes,和御三家相比,对 LoadBalancer 类型的服务的支持应该是众多表面差异中最醒目的一个了.类型为 LoadBalancer 的服务在 Kuberne ...
- 兼容火狐浏览器的select下拉框样式
经常遇到这样的问题,在使用bootstrap框架的时候select选择框的样式在火狐浏览器上继承的是浏览器本身的样式,跟谷歌等其他的浏览器样式对比很难看,并且很难调整,但是! 好东西来了,现在能调成跟 ...
- FFT的应用
FFT的应用 --讲稿 概述 FFT的模板很简单,大家都会背,于是出题的空间就在于建模了.FFT的题目难在建模,往往需要将问题抽象出来,经过一系列转化后得到乘积式的和,再赋予式子各个项的系数一定的意义 ...
- 显示所有用户,mysql的基本操作
可以实现显示数据库中所有用户. select user from mysql.user; select user,host,password from mysql.user; 给表创建用户,授权: ...