UVA.1640.The Counting Problem / BZOJ.1833.[ZJOI2010]数字计数(数位DP)
\(Description\)
求\([l,r]\)中\(0,1,\cdots,9\)每个数字出现的次数(十进制表示)。
\(Solution\)
对每位分别DP。注意考虑前导0: 在最后统计时,把0的答案减掉对应位的即可,在第\(i\)位的前导0会产生额外的\(10^{i-1}\)个答案。
#include <cstdio>
#include <cstring>
#include <algorithm>
int Ans[10],A[10],f[10][10],pw[10];
bool vis[10][10];
int DFS(int pos,int cnt,bool lim,int K)
{
if(!pos) return cnt;
if(!lim && vis[pos][cnt]) return f[pos][cnt];
int up=lim?A[pos]:9, res=0;
for(int i=0; i<=up; ++i)
res+=DFS(pos-1,cnt+(i==K),i==up&&lim,K);
if(!lim) vis[pos][cnt]=1,f[pos][cnt]=res;
return res;
}
int main()
{
pw[0]=1;
for(int i=1; i<=8; ++i) pw[i]=pw[i-1]*10;
int l,r;
while(scanf("%d%d",&l,&r),l&&r)
{
if(l>r) std::swap(l,r);
for(A[0]=0; r; r/=10) A[++A[0]]=r%10;
for(int i=0; i<=9; ++i)//每个数答案都是不同的。。别忘清空。
memset(vis,0,sizeof vis), Ans[i]=DFS(A[0],0,1,i);
int bit=A[0];
for(A[0]=0,--l; l; l/=10) A[++A[0]]=l%10;
for(int i=0; i<=9; ++i)
memset(vis,0,sizeof vis), Ans[i]-=DFS(A[0],0,1,i);
while(bit!=A[0]) Ans[0]-=pw[--bit];
for(int i=0; i<9; ++i) printf("%d ",Ans[i]);
printf("%d\n",Ans[9]);
}
return 0;
}
数字计数:
//824kb 52ms
//被longlong坑。。
#include <cstdio>
#include <cstring>
#include <algorithm>
typedef long long LL;
LL Ans[13],A[13],f[13][13],pw[13];
bool vis[13][13];
LL DFS(int pos,LL cnt,bool lim,int K)
{
if(!pos) return cnt;
if(!lim && vis[pos][cnt]) return f[pos][cnt];
int up=lim?A[pos]:9; LL res=0;
for(int i=0; i<=up; ++i)
res+=DFS(pos-1,cnt+(i==K),i==up&&lim,K);
if(!lim) vis[pos][cnt]=1,f[pos][cnt]=res;
return res;
}
int main()
{
pw[0]=1;
for(int i=1; i<=12; ++i) pw[i]=pw[i-1]*10ll;
LL l,r;
scanf("%lld%lld",&l,&r);
if(l>r) std::swap(l,r);
for(A[0]=0; r; r/=10) A[++A[0]]=r%10;
for(int i=0; i<=9; ++i)//每个数答案都是不同的。。别忘清空。
memset(vis,0,sizeof vis), Ans[i]=DFS(A[0],0,1,i);
int bit=A[0];
for(A[0]=0,--l; l; l/=10) A[++A[0]]=l%10;
for(int i=0; i<=9; ++i)
memset(vis,0,sizeof vis), Ans[i]-=DFS(A[0],0,1,i);
while(bit!=A[0]) Ans[0]-=pw[--bit];
for(int i=0; i<9; ++i) printf("%lld ",Ans[i]);
printf("%lld",Ans[9]);
return 0;
}
UVA.1640.The Counting Problem / BZOJ.1833.[ZJOI2010]数字计数(数位DP)的更多相关文章
- [ZJOI2010]数字计数 数位DP
最近在写DP,今天把最近写的都放上来好了,,, 题意:给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. 首先询问的是一个区间,显然是要分别求出1 ~ r ,1 ...
- [luogu2602 ZJOI2010] 数字计数 (数位dp)
传送门 Description 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. Input 输入文件中仅包含一行两个整数a.b,含义如上所述. Output ...
- Luogu P2602 [ZJOI2010]数字计数 数位DP
很久以前就...但是一直咕咕咕 思路:数位$DP$ 提交:1次 题解:见代码 #include<cstdio> #include<iostream> #include<c ...
- 洛谷P2602 [ZJOI2010]数字计数(数位dp)
数字计数 题目传送门 解题思路 用\(dp[i][j][k]\)来表示长度为\(i\)且以\(j\)为开头的数里\(k\)出现的次数. 则转移方程式为:\(dp[i][j][k] += \sum_{t ...
- 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] ...
- UVA 1640 The Counting Problem
https://vjudge.net/problem/UVA-1640 题意:统计区间[l,r]中0——9的出现次数 数位DP 注意删除前导0 #include<cmath> #inclu ...
- 1833: [ZJOI2010]count 数字计数——数位dp
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1833 省选之前来切一道裸的数位dp.. 题意 统计[a,b]中0~9每个数字出现的次数(不算 ...
- bzoj1833: [ZJOI2010]count 数字计数 数位dp
bzoj1833 Description 给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. Input 输入文件中仅包含一行两个整数a.b,含义如上所述. O ...
- [bzoj1833][ZJOI2010]count 数字计数——数位dp
题目: (传送门)[http://www.lydsy.com/JudgeOnline/problem.php?id=1833] 题解: 第一次接触数位dp,真的是恶心. 首先翻阅了很多很多一维dp,因 ...
随机推荐
- Spring Boot 源码分析 数据源 + Mybatis 配置
公司今年开始使用 Spring Boot 开发,当然使用 Spring Boot 也是大势所趋,尤其是现在微服务的趋向,当然是选择基于Spring Boot 的 Spring Cloud.(所谓的 S ...
- Dubbo学习笔记5:Dubbo整体框架分析
Dubbo的分层架构 本文将简单介绍Dubbo的分层架构设计,如下图是Dubbo官方的整体架构图: Dubbo官方提供的该架构图很复杂,一开始我们没必要深入细节,下面我们简单介绍下其中的主要模块. 其 ...
- win10内建子系统Linux
从cmd中下载linux和linux终端安装程序一样 最新要从商店购买(当然是免费) ubuntu openSUSE SUSE 3个 创建用户
- kombu源码Producer收获一
celery内置了kombu库,看了一下kombu的源码,从官网最简单的一个例子来分析---消息发布,源码如下: from __future__ import absolute_import, uni ...
- 机器学习&深度学习视频资料汇总
第一部分 基础语言 pandax视频教程 链接: https://pan.baidu.com/s/1pLqavVX 密码: fath python入门到精通 链接: https://pan.b ...
- python字典转datafarm,pandas
# coding:utf-8 import json import pandas as pd with open("./article_file/all_article.json" ...
- JS异常简单处理
有时候JS某一处报错会导致整个页面JS的运行出问题,于是想的简单研究一下JS的错误处理机制.更详细的可以自己参考网站研究: https://developer.mozilla.org/zh-CN/ ...
- 基于theano的多层感知机的实现
1.引言 一个多层感知机(Multi-Layer Perceptron,MLP)可以看做是,在逻辑回归分类器的中间加了非线性转换的隐层,这种转换把数据映射到一个线性可分的空间.一个单隐层的MLP就可以 ...
- 关于Hadoop未授权访问可导致数据泄露通知
尊敬的腾讯云客户: 您好!近日,外部媒体报道全球Hadoop服务器因配置不安全导致海量数据泄露,涉及使用Hadoop分布式文件系统(HDFS)的近4500台服务器,数据量高达5120 TB (5.12 ...
- metasploit利用漏洞渗透攻击靶机
1.网络测试环境构建 首先需要先配置好一个渗透测试用的网络环境,包括如图1所示的运行Kali Linux系统的计算机,如图2所示的老师给的Windows Server 2000系统的计算机.这两台计算 ...