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;
}

最新文章

  1. virtio-blk简介[转]
  2. SVN服务器&amp;客户端的搭建和使用
  3. Python字符串基础一
  4. WordPress主机
  5. spring4 security 4 +websocket 实现单点登录
  6. 提取图像(tif)中水体的矢量数据(shp)研究
  7. 怎么制作U盘系统/PE启动盘
  8. android_定义多个Activity及跳转
  9. CSS3教程:box-sizing属性的理解border、padding与容器宽度的关系
  10. mui开发app之自定义事件以更新其他页内容
  11. 一.windows环境下rabbitMQ的的安装和配置
  12. redis相关问题
  13. Asp.Net 之 js/jquery获取服务器端控件
  14. 阿里云实现putty私钥登录全过程
  15. springboot 定制错误页面
  16. 【DS】排序算法之快速排序(Quick Sort)
  17. Eclipse 去掉JavaScript Validator
  18. python分析apahce网站日志的例子
  19. java课程设计-坦克大战
  20. 2017 国庆湖南 Day3

热门文章

  1. GameObjectPool——Unity中的对象池
  2. 【Hibernate一】概述及入门
  3. android 程序更新(没有sdcard)
  4. SQL语法 之 操作语句
  5. Java程序实现密钥库的维护
  6. Cleaner ITweenPath Source
  7. Unity3D Android播放视频
  8. Unity Web前端研究
  9. [odroid-pc] ubuntu12.04 64bit Android4.0.3 源码编译报错及解决的方法
  10. SQL 防止注入