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的更多相关文章

  1. NBUT比赛 方格规律递推题

    题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=26901#problem/A 题意:有一个 2*n的格子里,你可以选择任意一个格 ...

  2. 汉诺塔III 递推题

    题目描述: 约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下.由小到大顺序串着由64个圆盘构成的塔.目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动 ...

  3. 【图灵杯 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项的值对 ...

  4. hdu 4517(递推枚举统计)

    小小明系列故事——游戏的烦恼 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)To ...

  5. hdu2073递推题

    无限的路 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submissio ...

  6. hdu2047.java递推题

    阿牛的EOF牛肉串 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total S ...

  7. dp递推题2010年吉林省省赛 1456: 逃票的chanming(3)

    1456: 逃票的chanming(3) 时间限制: 2 Sec  内存限制: 128 MB提交: 326  解决: 48[提交][状态][讨论版] 题目描述 这是一个神奇的国度.     这个国度一 ...

  8. hdu2587(递推)

    目前做过的最纠结的一道递推题. 情况比较多,比较复杂... 这题最主要的还是要推出当m=2 时和m>2时,用什么方法最优. 给个数据 n=3,m=2   需要48 n=3,m=3 需要81 如果 ...

  9. ACM之递推递归

    Hdu 2569 突破蝙蝠的包围,yifenfei来到一处悬崖面前,悬崖彼岸就是前进的方向,好在现在的yifenfei已经学过御剑术,可御剑轻松飞过悬崖. 现在的问题是:悬崖中间飞着很多红,黄,蓝三种 ...

随机推荐

  1. mysql之ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock'解决方法

    LAMPP安装完成之后,mysql -u root -p连不上,报这个错误: ERROR 2002 (HY000): Can't connect to local MySQL server throu ...

  2. go语言基础之defer延迟调用

    1.defer作用 关键字 defer ⽤于延迟一个函数或者方法(或者当前所创建的匿名函数)的执行.注意,defer语句只能出现在函数或方法的内部. 运行场景: defer语句经常被用于处理成对的操作 ...

  3. 如何更换Office 2013的product key?

    第一步 第二步 第三步 ... ... ... ... ^_^   参考资料 ======================== Change Product Key Office 2013 Home ...

  4. 关于Javascript你可能不知道的事

    NaN表示一个不能产生正常结果的运算结果.它不等于任何值,包括它自己.可以用isNaN(number)来检测. 同Java中的字符串一样,JS中的字符串是不可变的.也就是说一旦字符串被创建,就无法改变 ...

  5. C#装饰者模式实例代码

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace 装饰者 ...

  6. php 获得linux 机器的性能

    <?php $str = shell_exec('more /proc/stat'); $pattern = "/(cpu[0-9]? )[\s]+([0-9]+)[\s]+([0-9 ...

  7. 开发者和系统管理者最喜爱的开源工具Vim 起步学习的五个技巧

    多年来,我一直想学 Vim.如今 Vim 是我最喜欢的 Linux 文本编辑器,也是开发者和系统管理者最喜爱的开源工具.我说的学习,指的是真正意义上的学习.想要精通确实很难,所以我只想要达到熟练的水平 ...

  8. Transformer中引用iqd作为数据源导入报错TR1907与TR3312

    好久没和transform接触了,初次接触就给我送了个大礼,在选择好iqd文件执行最后一步导入的时候,要求我对数据源输入用户名密码,我连续输入了三次用户名和密码,在我十分肯定用户名和密码没错的情况下, ...

  9. easyui datagrid 分页保持checkbox选中状态

    刚开始我一直迷迷糊糊的写了很久,发现其实很简单 先给大家看看我的笨办法 var checkedItems = []; function ischeckItem() { for (var i = 0; ...

  10. eclipse因为js validator无法通过导致build workspace失败

    eclipse编译工程时时会validator js的errors和warnings,对于一些小型的项目,这当然没任何问题. 但是对于那些拥有大量js文件的web工程,js warnings通常会达到 ...