POJ 3286 How many 0's?(几多0?)
POJ 3286 How many 0's?(几多0?)
Time Limit: 1000MS Memory Limit: 65536K
|
【Description】 |
【题目描述】 |
|
A Benedict monk No.16 writes down the decimal representations of all natural numbers between and including m and n, m ≤ n. How many 0's will he write down? |
一个本尼迪克16号僧侣写下m与n之间并且包括mn的所有十进制自然数,m ≤ n。这之间他写下了多少个0? |
|
【Input】 |
【输入】 |
|
Input consists of a sequence of lines. Each line contains two unsigned 32-bit integers m and n, m ≤ n. The last line of input has the value of m negative and this line should not be processed. |
多组输入。每行有两个无符号32位整数m和n,m ≤ n。最后一行的m是负数,因此不该被执行。 |
|
【Output】 |
【输出】 |
|
For each line of input print one line of output with one integer number giving the number of 0's written down by the monk. |
对于每行输入数据输出一行一个整数,表示这个僧侣写了多少个0. |
|
【Sample Input - 输入样例】 |
【Sample Output - 输出样例】 |
|
10 11 100 200 0 500 1234567890 2345678901 0 4294967295 -1 -1 |
1 22 92 987654304 3825876150 |
【题解】
如果不考虑数据范围,这道题应该就是入门级别的数位DP(此处可参考HDU 2089)
不过这道的数据范围是unsigned int,无符号减法可能有问题,所以还是直接上int64吧。
这道题在具体的思路上基本一致,因为数据范围大了,就需要压缩一下空间,不能任性。
之后的计算方式大概可以变为:
计算0~N写了几个0,即个位上0写的次数,十位上0…,百位上的0…以此类推。
每一位按照其出现0的区间间隔与区间长度,计算这一位上写了几次0。
|
百位 |
[1000, 1099] |
[2000, 2099] |
[3000, 3099] |
[4000, 4099] |
…… |
|
十位 |
[100, 109] |
[200, 209] |
[300, 309] |
[400, 409] |
…… |
|
个位 |
[0, 0] |
[10, 10] |
[20, 20] |
[30, 30] |
…… |
以100为例:
个位:直接100/10 +1 = 11(懒)。
十位:100拆分成1 00
其中1表示进位的次数,完整区间数1-0=1,剩余区间的元素个数 0–0+1=1。
所以十位数的次数=0*10+1 = 1。
百位:到达最高位,结束。
结果:11+1 = 12。
以200为例:
个位:20 0,200/10 +1 = 21。
十位:2 10,完整区间数2-1=1,剩余区间的元素个数0-0+1=10。
剩余10>9,所以超过9的元素最多只能提供10个0
十位数的次数=1*10+10 = 11。
百位:结束。
结果:21+11 = 32。
其他数字的结果以此类推,就能计算0~N写了几个0。
【代码 C++】
#include<cstdio>
__int64 cmp[];
void rdy(){
int i;
for (cmp[] = i = ; i < ; ++i) cmp[i] = cmp[i - ] * ;
}
__int64 calculate(__int64 now){
if (now < ) return ;
int i = ;
__int64 right, left, opt = now / + ;
while (){
left = now / (cmp[i + ]);
right = now % (cmp[i + ]);
if (right < now){
opt += (left - )*(cmp[i]);
if (right >= cmp[i]) opt += cmp[i];
else opt += right + ;
++i;
}
else break;
}
return opt;
}
int main(){
rdy();
__int64 a, b;
while (scanf("%I64d%I64d", &a, &b)){
if (a < ) return ;
printf("%I64d\n", calculate(b) - calculate(a - ));
}
return ;
}
POJ 3286 How many 0's?(几多0?)的更多相关文章
- POJ 3286 How many 0's?
题目链接 题意 :写下m到n之间所有的数,会写多少个0. 思路 :先算0到m的,再算0到n的,最后相减. 网上有位大神是这么推的,看下面.... 首先转化成求 [0, x] 中所有数中,含有的 0 的 ...
- POJ 1979 Red and Black dfs 难度:0
http://poj.org/problem?id=1979 #include <cstdio> #include <cstring> using namespace std; ...
- poj 1789 Truck History 最小生成树 prim 难度:0
Truck History Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 19122 Accepted: 7366 De ...
- 创建或打开解决方案时提示"DotNetCore.1.0.1-SDK.1.0.0.Preview2-003131-x86"错误的解决方案
提示"DotNetCore.1.0.1-SDK.1.0.0.Preview2-003131-x86"错误的解决方案: 1.检查是否有C:\Program Files (x86)\d ...
- Android requires compiler compliance level 5.0 or 6.0. Found '1.4' instead的解决办法
今天在导入工程进Eclipse的时候竟然出错了,控制台输出的是: [2013-02-04 22:17:13 - takepicture] Android requires compiler compl ...
- 字符串数组初始化0 与memset 0 效率的分析
转自:http://www.xuebuyuan.com/1722207.html 结合http://blog.sina.com.cn/s/blog_59d470310100gov8.html来看. 最 ...
- bootstrap2.0与3.0的区别
在阅读这篇bootstrap2.0与3.0的区别的文章之前,大家一定要先了解什么是响应式网站设计?推荐大家看看这篇"教你快速了解响应式网站设计" . 我觉得bootstrap的可视 ...
- centos7.2环境elasticsearch-5.0.1+kibana-5.0.1+zookeeper3.4.6+kafka_2.9.2-0.8.2.1部署详解
centos7.2环境elasticsearch-5.0.1+kibana-5.0.1+zookeeper3.4.6+kafka_2.9.2-0.8.2.1部署详解 环境准备: 操作系统:centos ...
- ASP.Net MVC3安全升级导致程序集从3.0.0.0变为3.0.0.1
开发环境一般引用的是本机 C:\Program Files (x86)\Microsoft ASP.NET\ASP.NET MVC 3\Assemblies下的System.Web.Mvc.dll,当 ...
随机推荐
- Linux 的 Crontab 命令运用(转)
cron来源于希腊单词chronos(意为“时间”),是linux系统下一个自动执行指定任务的程序.例如,你想在每晚睡觉期间创建某些文件或文件夹的备份,就可以用cron来自动执行. 服务的启动和停止 ...
- lamp环境编译(apache2.4.7 php5.4.25 mysql 5.5.23)
环境要求 gcc.gcc-c++.cmake.bison(可能)支持 1.yum install gcc gcc-c++ cmake bison 2.修改yum配置,达到搜索本地设置 移走或改名/et ...
- Javascript 类与静态类的实现-js面向对象
在Javascript里,对面向对象并没有一个直接的实现,对于代码方面也是非常的灵活. 今天所要说的就是,如何在Javascript里写类与静态类,这是本人一惯用的方法,你也可以有更为方便的,也可以发 ...
- java hashMap缓存简单实现
直接上代码,干货: import java.util.HashMap; import java.util.Map; /** * map缓存 * @author ming * * @param < ...
- Compress a Folder/Directory via Perl5
Compress a Folder/Directory via Perl5 tested in Windows, Mac OS X, Ubuntu16.04 #!/usr/bin/perl #压缩指定 ...
- JavaEE基础(三)
1.Java语言基础(逻辑运算符的基本用法) A:逻辑运算符有哪些 &,|,^,! &&,|| B:案例演示 逻辑运算符的基本用法 注意事项: a:逻辑运算符一般用于连接boo ...
- ecshop添加商品选择品牌时如何按拼音排序
ECSHOP后台添加新商品时,有一个选择品牌的下拉框,如果品牌太多,在下拉框里查找起来很不方便. 我想给“下拉框里的品牌列表”按品牌名的拼音排序,比如有“中国水利出版社” “中国人民出版社” 这两个品 ...
- Serializable接口使用纪实
这两天依领导要求使用sonar工具测试了一下项目代码,其中有一个问题是 而这个类的结构大概是这样的: public class Demo<T> implements Serializabl ...
- JAVA中int、String的类型相互转换
int -> String int i=12345;String s="";第一种方法:s=i+"";第二种方法:s=String.valueOf(i); ...
- SlickGrid example 8:折线图
根据数据生成折线图,使用相当简单,也很容易. 主要方法: 数据: var vals = [12,32,5,67,5,43,76,32,5]; 生成折线图: $("testid&quo ...