BZOJ 1833 数字计数 数位DP
做的第一道数位DP题,听说是最基础的模板题,但还是花了好长时间才写出来。。。。。
想深入了解下数位DP的请点这里
先设dp数组dp[i][j][k]表示数位是i,以j开头的数k出现的次数
有 

数位dp的题一般都会用到前缀数组,题目要求我们求b-a这个区间里各个数码出现的次数,我们可以分别求出(0,b)和(0,a-1)然后相减即可
具体分析请看代码,写的还算详细
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll dp[][][];
ll ans[];//用来储存每个数码出现的次数
ll bin[];//表示i位数中数码i出现的次数
ll d[];//这个用来存储数的每一位
void rule(){
bin[]=;
for(int i=;i<;i++) bin[i]=bin[i-]*;
for(int i=;i<;i++) dp[][i][i]=;
for(int i=;i<=;i++){
for(int j=;j<=;j++){
for(int z=;z<=;z++){
for(int k=;k<=;k++)
dp[i][j][z]+=dp[i-][k][z];//比如i=2,j=2时,所求数字范围应该是200-299,这一步把0-99中各数码出现次数加进去
dp[i][z][z]+=bin[i-];//这一位这是把200-299总共出现了100次的2给加进去
}
}
}
}
void solve(ll x,int flag){
ll tmpx=x;//存储传进来的x
int cnt=;//记录x的位数
memset(d,,sizeof(d));
while(x){
d[++cnt]=x%;
x/=;
}
for(int i=;i<cnt;i++){//这一步是最高位为0的,这些数都不会受到x的上限限制,都可以直接加进来
for(int j=;j<=;j++){
for(int k=;k<=;k++)
ans[k]+=dp[i][j][k]*flag;
}
}
int tmpt=cnt;
while(cnt){//可以举个456的例子来仔细分析一下
for(int i=;i<d[cnt];i++){//注意这里是小于不是等于,保证上限不被取到,在后面再被处理
if(!i&&cnt==tmpt) continue;//这种情况在最高位为0时已经统计过了,不能重复
for(int j=;j<=;j++){
ans[j]+=dp[cnt][i][j]*flag;//不是上限的时候都直接加
}
}
ans[d[cnt]]+=(tmpx%bin[cnt]+)*flag;cnt--;//随着while循环,上限一步步的被处理
}//简述一下过程(456),就是第一个for处理了0-399,然后把首位4的57次加上,第二个for,处理的0-49......就这样一步步往下
}
int main(){
ll a,b;scanf("%lld%lld",&a,&b);
rule();
solve(b,);solve(a-,-);//1和-1是符号位,分别是加和减
for(int i=;i<;i++)
printf("%lld%c",ans[i],i==?'\n':' ');
return ;
}
BZOJ 1833 数字计数 数位DP的更多相关文章
- UVA.1640.The Counting Problem / BZOJ.1833.[ZJOI2010]数字计数(数位DP)
题目链接 \(Description\) 求\([l,r]\)中\(0,1,\cdots,9\)每个数字出现的次数(十进制表示). \(Solution\) 对每位分别DP.注意考虑前导0: 在最后统 ...
- 1833: [ZJOI2010]count 数字计数——数位dp
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1833 省选之前来切一道裸的数位dp.. 题意 统计[a,b]中0~9每个数字出现的次数(不算 ...
- 【BZOJ-1833】count数字计数 数位DP
1833: [ZJOI2010]count 数字计数 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 2494 Solved: 1101[Submit][ ...
- [BZOJ 1833] 数字计数
Link: BZOJ 1833 传送门 Solution: 比较明显的数位DP 先预处理出1~9和包括前导0的0的个数:$pre[i]=pre[i-1]*10+10^{digit-1}$ (可以分为首 ...
- bzoj1833: [ZJOI2010]count 数字计数(数位DP+记忆化搜索)
1833: [ZJOI2010]count 数字计数 题目:传送门 题解: 今天是躲不开各种恶心DP了??? %爆靖大佬啊!!! 据说是数位DP裸题...emmm学吧学吧 感觉记忆化搜索特别强: 定义 ...
- [bzoj1833][ZJOI2010]count 数字计数——数位dp
题目: (传送门)[http://www.lydsy.com/JudgeOnline/problem.php?id=1833] 题解: 第一次接触数位dp,真的是恶心. 首先翻阅了很多很多一维dp,因 ...
- 【题解】P2602 数字计数 - 数位dp
P2602 [ZJOI2010]数字计数 题目描述 给定两个正整数 \(a\) 和 \(b\) ,求在 \([a,b]\) 中的所有整数中,每个数码(digit)各出现了多少次. 输入格式 输入文件中 ...
- bzoj1833: [ZJOI2010]count 数字计数 数位dp
bzoj1833 Description 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. Input 输入文件中仅包含一行两个整数a.b,含义如上所述. O ...
- Luogu P2602 [ZJOI2010]数字计数 数位DP
很久以前就...但是一直咕咕咕 思路:数位$DP$ 提交:1次 题解:见代码 #include<cstdio> #include<iostream> #include<c ...
随机推荐
- 【示例】Spring Quartz入门
JAVA 针对定时任务,有 Timer,Scheduler, Quartz 等几种实现方式,其中最常用的应该就是 Quartz 了. 一. Quartz的基本概念 在开始之前,我们必须了解以下的几个基 ...
- MySQL主主复制、主从复制
意思: 主机A上有mysql1,主机B上有mysql2,mysql1新建库D,则mysql2也新建库D,mysql1原有库A.B.C,mysql2也原有库A.B.C,总之mysql1和mysql2一样 ...
- reshape2
require(reshape2)x = data.frame(subject = c("John", "Mary"), tim ...
- 利用JavaScriptSOAPClient直接调用webService --完整的前后台配置与调用示例
JavaScriptSoapClient下载地址:https://archive.codeplex.com/?p=javascriptsoapclient JavaScriptSoapClient的D ...
- Select2 添加默认值
折腾很久才解决问题 $.ajax({ url: '@Url.Action("GetSystemSzzdItem", "CangpinGushi")', type ...
- pc网页中嵌入百度地图
pc网页中嵌入百度地图 1 打开百度地图生成器: http://api.map.baidu.com/lbsapi/creatmap/ 2 设置好了之后,点击获取代码,将代码粘贴到文件中保存为html文 ...
- label和span的区别
label标签主要用于绑定一个表单元素,当点击label标签的时候,被绑定的表单元素就会获得输入焦点. <div class="form-group col-lg-12"&g ...
- STL_string.vector中find到的iterator的序号
ZC:注意,printf("0x%08X\n",vtr.end()); 打印出来 应该就是 0x00000000,∵ 它就是 指向最后一个元素的后面,应该是理解成 无意义 ...
- 力扣(LeetCode) 66. 加一
给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一. 最高位数字存放在数组的首位, 数组中每个元素只存储一个数字. 你可以假设除了整数 0 之外,这个整数不会以零开头. 示例 1: 输入 ...
- d3选择全部子节点,不知道class和id
https://github.com/d3/d3-selection/issues/63 selection.selectAll("*")