Description

问 \([L,R]\) 中0-9的个数.

Sol

数位DP.

预处理好长度为 \(i\), 最高位为 \(j\) 的数位之和.

然后从上往下计算,不要忘记往下走的同时要把高位的贡献加上去..

Code

/**************************************************************
Problem: 1833
User: BeiYu
Language: C++
Result: Accepted
Time:40 ms
Memory:1396 kb
****************************************************************/ #include <cstdio>
#include <cstring>
#include <iostream>
using namespace std; typedef long long LL;
const int N = 65; struct S {
LL a[10];
S(LL v=0) { for(int i=0;i<10;i++) a[i]=v; }
}f[N][10][2]; S operator + (const S &a,const S &b) {
S c;for(int i=0;i<10;i++) c.a[i]=a.a[i]+b.a[i];
return c;
}
S operator - (const S &a,const S &b) {
S c;for(int i=0;i<10;i++) c.a[i]=a.a[i]-b.a[i];
return c;
}
S operator * (const S &a,const LL &b) {
S c;for(int i=0;i<10;i++) c.a[i]=a.a[i]*b;
return c;
}
void Print(const S &a) { for(int i=0;i<9;i++) cout<<a.a[i]<<" ";cout<<a.a[9]; } LL l,r;
LL pow10[N]; inline LL Pow(LL a,LL b,LL r=1) { return pow10[b]; }
void init() {
pow10[0]=1;
for(int i=1;i<=15;i++) pow10[i]=pow10[i-1]*10LL; for(int i=0;i<10;i++) {
f[1][i][0]=f[1][i][1]=f[1][i-1][0];
f[1][i][0].a[i]+=1,f[1][i][1].a[i]+=1;
}
for(int l=2;l<=14;l++) {
f[l][0][0]=f[l-1][9][0];
f[l][0][1]=f[l-1][9][1];
f[l][0][1].a[0]+=Pow(10,l-1);
for(int i=1;i<10;i++) {
f[l][i][0]=f[l][i-1][0]+f[l-1][9][1];
f[l][i][0].a[i]+=Pow(10,l-1);
f[l][i][1]=f[l][i-1][1]+f[l-1][9][1];
f[l][i][1].a[i]+=Pow(10,l-1);
}
} // for(int l=1;l<=5;l++) for(int i=0;i<10;i++) {
// cout<<l<<":"<<i<<endl;
// Print(f[l][i][0]),Print(f[l][i][1]);
// cout<<"-------------------------------"<<endl;
// }
}
S calc(LL x) {
LL g=0,nn;S r,t;
for(int i=13;~i;i--) {
if(x/pow10[i]) {
nn=(LL)(x/pow10[i])*pow10[i];
r=r+t*nn; t.a[x/pow10[i]]++; r=r+f[i+1][x/pow10[i]-1][g];
g=1;
// cout<<i+1<<" "<<x/pow10[i]-1<<" "<<g<<endl;
}else {
if(g) t.a[0]++;
}x%=pow10[i];
// cout<<i<<" ";Print(r);
}return r;
}
int main() {
init(); cin>>l>>r; S ans1=calc(r+1);
S ans2=calc(l); // Print(ans1),Print(ans2);
Print(ans1-ans2);
return 0;
}

  

BZOJ 1833: [ZJOI2010]count 数字计数的更多相关文章

  1. BZOJ 1833: [ZJOI2010]count 数字计数( dp )

    dp(i, j, k)表示共i位, 最高位是j, 数字k出现次数. 预处理出来. 差分答案, 对于0~x的答案, 从低位到高位进行讨论 -------------------------------- ...

  2. [BZOJ 1833] [ZJOI2010] count 数字计数 【数位DP】

    题目链接:BZOJ - 1833 题目分析 数位DP .. 用 f[i][j][k] 表示第 i 位是 j 的 i 位数共有多少个数码 k . 然后差分询问...Get()中注意一下,如果固定了第 i ...

  3. bzoj 1833 [ZJOI2010]count 数字计数(数位DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1833 [题意] 统计[a,b]区间内各数位出现的次数. [思路] 设f[i][j][k ...

  4. BZOJ 1833 ZJOI2010 count 数字计数 数位DP

    题目大意:求[a,b]间全部的整数中0~9每一个数字出现了几次 令f[i]为i位数(算前导零)中每一个数出现的次数(一定是同样的,所以仅仅记录一个即可了) 有f[i]=f[i-1]*10+10^(i- ...

  5. bzoj 1833: [ZJOI2010]count 数字计数【数位dp】

    非典型数位dp 先预处理出f[i][j][k]表示从后往前第i位为j时k的个数,然后把答案转换为ans(r)-ans(l-1),用预处理出的f数组dp出f即可(可能也不是dp吧--) #include ...

  6. 1833: [ZJOI2010]count 数字计数

    1833: [ZJOI2010]count 数字计数 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 2951  Solved: 1307[Submit][ ...

  7. 【BZOJ】1833 [ZJOI2010]count 数字计数

    [算法]数位DP [题解] 记忆化搜索 #include<cstdio> #include<algorithm> #include<cstring> #define ...

  8. 1833: [ZJOI2010]count 数字计数 - BZOJ

    Description给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次.Input输入文件中仅包含一行两个整数a.b,含义如上所述.Output输出文件中包含一 ...

  9. 【BZOJ】1833: [ZJOI2010] count 数字计数(数位dp)

    题目 传送门:QWQ 分析 蒟蒻不会数位dp,又是现学的 用$ dp[i][j][k] $ 表示表示长度为i开头j的所有数字中k的个数 然后预处理出这个数组,再计算答案 代码 #include < ...

随机推荐

  1. java中两个字符串如何比较大小

    有三种方法实现 第一种直接用字符串类的compareTo方法: 1 2 3   String t1="20131011";   String t2="20131030&q ...

  2. linux系统下的权限知识梳理

    下面对linux系统下的有关权限操作命令进行了梳理总结,并配合简单实例进行说明.linux中除了常见的读(r).写(w).执行(x)权限以外,还有其他的一些特殊或隐藏权限,熟练掌握这些权限知识的使用, ...

  3. PAT 1039. 到底买不买(20)

    小红想买些珠子做一串自己喜欢的珠串.卖珠子的摊主有很多串五颜六色的珠串,但是不肯把任何一串拆散了卖.于是小红要你帮忙判断一下,某串珠子里是否包含了全部自己想要的珠子?如果是,那么告诉她有多少多余的珠子 ...

  4. 微信小程序购物商城系统开发系列-目录结构

    上一篇我们简单介绍了一下微信小程序的IDE(微信小程序购物商城系统开发系列-工具篇),相信大家都已经蠢蠢欲试建立一个自己的小程序,去完成一个独立的商城网站. 先别着急我们一步步来,先尝试下写一个自己的 ...

  5. 关于SIGSEGV错误及处理方法(转)

    转自:http://blog.csdn.net/brace/article/details/1102422   今天编程遇到了SIGSEGV错误,比较困惑,所以找了些资料,总结一下: (1)官方说法是 ...

  6. Java中的instanceof关键字

    instanceof是Java的一个二元操作符,和==,>,<是同一类东东.由于它是由字母组成的,所以也是Java的保留关键字.它的作用是测试它左边的对象是否是它右边的类的实例,返回boo ...

  7. VS一直停留在“正在还原nuget程序包”

    VS一直停留在“正在还原nuget程序包” 在开发何问起收藏夹的时候,准备在WinFrom中加入网页浏览器,于是下载了一个CEFSharp的源码,生成解决方案的时候,一直提示“正在还原nuget程序包 ...

  8. 微信小程序开发工具使用与设计规范(二)

    [未经作者本人同意,请勿以任何形式转载] 上一篇文章主要分析了微信小程序应用场景和优劣势.本篇你可以学习到: 如何使用小程序开发工具写一个Hello World 微信小程序设计规范 微信小程序项目结构 ...

  9. 【六年开源路】FineUI家族今日全部更新!

      FineUI(开源版) 基于 ExtJS 的开源 ASP.NET 控件库 FineUI的使命 创建 No JavaScript,No CSS,No UpdatePanel,No ViewState ...

  10. 在oracle中,如何当前系统时间往前推7天

    ' day from dual 另附: 当前时间减去7分钟的时间 ' MINUTE from dual 当前时间减去7小时的时间 ' hour from dual 当前时间减去7天的时间 ' day ...