zoukankan      html  css  js  c++  java
  • 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
    ",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
    ",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
    ",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
    ",i,b[i],a[i],tmp);
    				continue;
    			}
    			if(k==0)
    			{
    				sum+=b[i]*a[i];
    				//printf("i==%I64d  %I64d %I64d %I64d
    ",i,b[i],a[i],sum);
    				continue;
    			}
    		}
    		printf("%I64d
    ",sum);
    	}
    	return 0;
    }
    
  • 相关阅读:
    【五种方法】mybatis使用Map返回时,当value为空时不显示key
    【日常填坑】com.zaxxer.hikari.util.DriverDataSource : Registered driver with driverClassName=com.mysql.
    NVL2(表达式1,表达式2,表达式3)表达式1带或者,与
    oracle存储过程is和begin之间的参数说明
    Idea全局搜索没有把html文件显示出来
    JAVA
    (日常踩坑)idea启动多个tomcat时,报Invalid command '' received警告
    java中impl作用
    localhost:8080要加项目名能访问的解决方法
    【ubuntu】搭建mysql5.7
  • 原文地址:https://www.cnblogs.com/ziyi--caolu/p/3202329.html
Copyright © 2011-2022 走看看