noj1475(递推题)统计多少个1
http://acm.nbut.cn/Problem/view.xhtml?id=1475
题意:给出一个数,需要你统计在这个数范围内有多少个1........
思路:从高位到低位计算,例如1312
最高位==1,说明最高位为一个的数字1000——1312,有313种
次高位==3>1,那么先思考它本身为1的情况,只有三位数的时候,范围为1——312,其中第三位为1的情况有100种,在这情况下,如果有四位数,1——1312,第三位为1的情况,应该是它只有3位数的时候为1的情况加上有四位数时为1的情况,那么应该是200种
次低位==1,同样的它只有两位的时候本身为1的情况只有3种(10,11,12),但在小于三位数(1--99)的情况下,第二位为1的情况有10种,再综合三位数与四位数的情况,次低位为1的情况有10*(13)+3==133种
最低位==2>1,那么本身为1的情况只有一种,那不止一位的情况下最低位为1有1*(n/10)种,再加上自己本身为132种
总共为778种
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
using namespace std;
typedef __int64 ss;
__int64 a[20]; int main()
{
a[0]=0;
a[1]=1;
a[2]=10;
a[3]=100;
a[4]=1000;
a[5]=10000;
a[6]=100000;
a[7]=1000000;
a[8]=10000000;
a[9]=100000000;
a[10]=1000000000;
//s[11]=10000000000;
//s[12]=100000000000;
//s[13]=1000000000000;
ss n;
while(scanf("%I64d",&n)>0)
{
ss b[15];
ss len=(ss)log10((double)n)+1,sum=0;
for(ss i=len;i>=1;i--)
{
if(i==len)
{
b[i]=n%(ss)(pow(10.0,(double)(i-1))+0.5);
}
else if(i==1)
{
b[i]=n/10;
}
else
{
b[i]=n/(ss)(pow(10.0,(double)i)+0.5);
}
}
for(ss i=len;i>=1;i--)
{
ss k=n%(ss)(pow(10.0,(double)i)+0.5)/(ss)(pow(10.0,(double)(i-1))+0.5);
//printf(" k=%I64d\n",k);
ss ans=0;
if(i==len)
{
if(k==1)
{
ans=b[i]+1;
}
if(k>1)
{
ans=a[i];
}
sum+=ans;
//printf("i==%I64d %I64d %I64d %I64d\n",i,b[i],a[i],sum);
continue;
}
if(k>1)
{
ss ans=0;
ans+=b[i]+1;
sum+=ans*a[i];
//printf("i==%I64d %I64d %I64d %I64d\n",i,b[i],a[i],sum);
continue;
}
if(k==1)
{
ss ans=0;
ans+=b[i];
sum+=ans*a[i];
ss tmp=n%(ss)(pow(10.0,(double)(i-1))+0.5);
sum+=tmp+1;
//printf("i==%I64d %I64d %I64d tmp=%I64d\n",i,b[i],a[i],tmp);
continue;
}
if(k==0)
{
sum+=b[i]*a[i];
//printf("i==%I64d %I64d %I64d %I64d\n",i,b[i],a[i],sum);
continue;
}
}
printf("%I64d\n",sum);
}
return 0;
}
noj1475(递推题)统计多少个1的更多相关文章
- NBUT比赛 方格规律递推题
题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=26901#problem/A 题意:有一个 2*n的格子里,你可以选择任意一个格 ...
- 汉诺塔III 递推题
题目描述: 约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下.由小到大顺序串着由64个圆盘构成的塔.目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动 ...
- 【图灵杯 F】一道简单的递推题(矩阵快速幂,乘法模板)
Description 存在如下递推式: F(n+1)=A1*F(n)+A2*F(n-1)+-+An*F(1) F(n+2)=A1*F(n+1)+A2*F(n)+-+An*F(2) - 求第K项的值对 ...
- hdu 4517(递推枚举统计)
小小明系列故事——游戏的烦恼 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)To ...
- hdu2073递推题
无限的路 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submissio ...
- hdu2047.java递推题
阿牛的EOF牛肉串 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- dp递推题2010年吉林省省赛 1456: 逃票的chanming(3)
1456: 逃票的chanming(3) 时间限制: 2 Sec 内存限制: 128 MB提交: 326 解决: 48[提交][状态][讨论版] 题目描述 这是一个神奇的国度. 这个国度一 ...
- hdu2587(递推)
目前做过的最纠结的一道递推题. 情况比较多,比较复杂... 这题最主要的还是要推出当m=2 时和m>2时,用什么方法最优. 给个数据 n=3,m=2 需要48 n=3,m=3 需要81 如果 ...
- ACM之递推递归
Hdu 2569 突破蝙蝠的包围,yifenfei来到一处悬崖面前,悬崖彼岸就是前进的方向,好在现在的yifenfei已经学过御剑术,可御剑轻松飞过悬崖. 现在的问题是:悬崖中间飞着很多红,黄,蓝三种 ...
随机推荐
- OpenMP 线程同步之临界区
多核/多线程编程中肯定会用到同步互斥操作.除了互斥变量以为,就是临界区. 临界区是指在用一时刻只允许一个线程执行的一段用{...},包围的代码段. 在OpenMP中临界区声明方法如下: #pragma ...
- jQuery/javascript实现IP/Mask自动联想功能
之前做一个云计算的项目,涉及到一个安全组自动联想的功能,思想是这样的: 安全组规则之间是可以相互引用的,也可以自己是自己手动输入的ip/mask,这时候可以加一个功能,实现securityGroupI ...
- CentOS6.4下Samba服务器的安装与配置
一.先恶狠狠地吐槽一下: 这篇随笔真是让我折腾了2天2夜才敢下笔写!!!为什么呢?之前是通过去Samba的官网下载的源码包,也就是.tar.gz来进行安装配置,不过这个让我折腾来折腾去就是没折腾出结果 ...
- 神奇的container_of
container_of是linux内核中常用的一个宏,这个宏的功能是,根据某个结构体字段的指针,找到对应的结构体指针. 话不多说,先上源码: /** * container_of - cast a ...
- 取球游戏_nyoj_518(博弈-蓝桥杯原题).java
取球游戏 时间限制: 1000 ms | 内存限制: 65535 KB 难度: 2 描述 今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下 ...
- 讯飞语音唤醒SDK集成流程
唤醒功能,顾名思义,通过语音,唤醒服务,做我们想做的事情. 效果图(开启应用后说讯飞语音或者讯飞语点唤醒) 源码下载 地址:http://download.csdn.net/detail/q48788 ...
- Python 默认参数
定义默认参数 定义函数的时候,还可以有默认参数. 例如Python自带的 int() 函数,其实就有两个参数,我们既可以传一个参数,又可以传两个参数: >>> int('123') ...
- js正则表达式test方法、exec方法与字符串search方法区别
1.正则表达式test方法 test() 方法用于检测一个字符串是否匹配某个模式 返回值: 如果字符串 string 中含有与 RegExpObject 匹配的文本,则返回 true,否则返回 fal ...
- windows vbs显示桌面命令
windows vbs显示桌面命令 CreationTime--2018年7月26日11点32分 Author:Marydon Dim shell Set shell = CreateObject ...
- css background-position结合disaply:inline-block使用
$(".icon-a").on('click', function (e) { if ($(this).next().css('display') == "none&qu ...