zoukankan      html  css  js  c++  java
  • 数字统计问题

    #include<stdio.h>
    #include<math.h> 
    
    void GetParamater(int a[7][10],int n,int m,int sum0[7]);
    void GetSum(int data,int sum[10],int a[7][10]);
    
    int main(){
    	int a[7][10] ;
    	int data,sum[10],sum0[7];
    
    	GetParamater(a,6,10,sum0);
    	//printf("%lf\n",log10(92345));
    
    	while(scanf("%d",&data)){
    		GetSum(data,sum,a);
    		sum[0]-=sum0[(int)log10(data)+1];
    		for(int x=0;x<10;x++){
    			printf("%d\n",sum[x]);
    		}
    	}
    	
    	return 0;
    }
    
    void GetParamater(int a[7][10],int n,int m,int sum0[7]){
    
    	for(int k=0;k<m;k++)
    		a[0][k] = 0;
    	sum0[0]=0;
    	for(int i=1,temp=1;i<=n;i++){
    		for(int j=0;j<m;j++){
    			a[i][j] = 10*a[i-1][j]+ temp;
    			//printf("%d  ",a[i][j]);
    		}
    		sum0[i]=sum0[i-1]+temp;
    		temp *= 10;
    		//putchar('\n');
    	}
    	 
    }
    
    void GetSum(int data,int sum[10],int a[7][10]){
    	
    	for(int i=0;i<10;i++){
    		sum[i]=0;
    	}
    	
    	while(data!=0){
    		int k = (int)log10(data);
    		//表示最高位是多少!
    		int p = pow(10,k);
    		int high = data/p;
    		//printf("k=%d  p=%d  high=%d\n",k,p,high);
    		for(int x=0;x<high;x++){
    			sum[x]+=p;
    			for(int y=0;y<10;y++){
    				sum[y]+=a[k][y];
    			}
    		}
    		//printf("data/p  = %d   p=%d\n",data%p+1,p);
    		sum[high]+=(data%p+1);
    		//printf("sum[high]%d  %d\n",sum[high],high);
    
    		//printf("%d\n",data);
    		data%=p;
    		p/=10;
    	}
    	//printf("data=%d\n",data);
    }
    

    数字统计问题

    一本书的页码从自然数1 开始顺序编码直到自然数n。书的页码按照通常的习惯编排,每个页码都不含多余的前导数字0。例如,第6 页用数字6 表示,而不是06 006 等。数字计数问题要求对给定书的总页码n,计算出书的全部页码中分别用到多少次数字0129

    编程任务:给定表示书的总页码的10 进制整数n (1≤n≤10^9) 。编程计算书的全部页码中分别用到多少次数字0129

    输入: 每个输入只有1 行,给出表示书的总页码的整数n

    输出: 程序运行结束时,输出有10行,在第k行输出页码中用到数字k-1 的次数,k=1210



  • 相关阅读:
    26. Remove Duplicates from Sorted Array(js)
    25. Reverse Nodes in k-Group(js)
    24. Swap Nodes in Pairs(js)
    23. Merge k Sorted Lists(js)
    22. Generate Parentheses(js)
    21. Merge Two Sorted Lists(js)
    20. Valid Parentheses(js)
    19. Remove Nth Node From End of List(js)
    18. 4Sum(js)
    17. Letter Combinations of a Phone Number(js)
  • 原文地址:https://www.cnblogs.com/Acmen/p/2246351.html
Copyright © 2011-2022 走看看