博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数字统计问题
阅读量:6276 次
发布时间:2019-06-22

本文共 1873 字,大约阅读时间需要 6 分钟。

一本书的页码从自然数1 开始顺序编码直到自然数n。书的页码按照通常的习惯编排,每个页码都不含多余的前导数字0。例如,第6 页用数字6 表示,而不是06 或006 等。数字计数问题要求对给定书的总页码n,计算出书的全部页码中分别用到多少次数字0,1,2,…,9。
编程任务:给定表示书的总页码的10 进制整数n (1≤n≤10^9) 。编程计算书的全部页码中分别用到多少次数字0,1,2,…,9。
输入: 每个输入只有1 行,给出表示书的总页码的整数n。
输出: 程序运行结束时,输出有10行,在第k行输出页码中用到数字k-1 的次数,k=1,2,…,10。
复制代码
#include <iostream> 
#include <string> 
#include <sstream> 
#include <cmath> 
#include <vector> 
using namespace std; 
double string_to_num(string str) 
{//字符串转换为double 
    double back; 
    istringstream instr(str); 
    instr>>back; 
    return back; 
int main() 
    int len; 
    double mm;  
    int countNum[10] = {0};//保存统计结果
    vector<int> posNum; 
    string pageNum; 
    cin>>pageNum; 
    double num = string_to_num(pageNum); 
    len = pageNum.size(); 
    if( len <= 1 ) 
    {//个位数
        for(int i = 1; i <= int(num); i++) 
            countNum[i] += 1; 
    } 
    else
    { 
        const char* p = pageNum.c_str(); 
        for(int i = 0; i < len; i++) 
        { 
            int curPosNum = int( *(p+i) ) - 48;//当前处理位置上的数字
            mm = pow(10.0,len-i-2) * (len-i-1);//由书上公式得f(n-1)=(n-1)pow(10,n-2)
            if( mm != 0) 
            {//还不是个位
                //对低于当前位的位置先统计,当前位留到下一次
                for(int j = 0; j < curPosNum; j++) 
                { 
                    for(int k = 0; k < 10; k++) 
                        countNum[k] += mm; 
                    countNum[j] += pow(10.0,len-i-1); 
                } 
                if( !posNum.empty() ) 
                { 
                    for(int m = 0; m < posNum.size(); m++) 
                    { 
                        int tt = posNum.at(m); 
                        countNum[tt] += ( pow(10.0,len-i-1)*curPosNum ); 
                    }        
                }    
                posNum.push_back(curPosNum);
                if( i == 0) 
                {
                    //去掉多余的0
                    for(int j = 0; j < len-1; j++) 
                        countNum[0] = countNum[0] - (len-j-1)*pow(10.0,j)*9.0; 
                    //去掉全0,包括一个0的情况
                    countNum[0] -= len-1; 
                }                        
            } 
            else
            {//位置来到个位上了
                for(int m = 0; m < posNum.size(); m++) 
                { 
                    int tm = posNum.at(m); 
                    countNum[tm] += 1; 
                } 
                for(int n = 1; n <= curPosNum; n++) 
                { 
                    countNum[n] += 1; 
                    for(int mn = 0; mn < posNum.size(); mn++) 
                    { 
                        int tmn = posNum.at(mn); 
                        countNum[tmn] += 1; 
                    } 
                } 
            } 
        } 
    } 
    for(int i = 0; i < 10; i++) 
    {
        cout<<countNum[i]<<endl; 
    }
    return 0; 
}
复制代码
本文转自Phinecos(洞庭散人)博客园博客,原文链接:http://www.cnblogs.com/phinecos/archive/2008/12/14/1354780.html,如需转载请自行联系原作者
你可能感兴趣的文章
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>
《Arduino家居安全系统构建实战》——1.5 介绍用于机器学习的F
查看>>
jquery中hover()的用法。简单粗暴
查看>>
线程管理(六)等待线程的终结
查看>>
spring boot集成mongodb最简单版
查看>>
DELL EqualLogic PS存储数据恢复全过程整理
查看>>
《Node.js入门经典》一2.3 安装模块
查看>>
《Java 开发从入门到精通》—— 2.5 技术解惑
查看>>
Linux 性能诊断 perf使用指南
查看>>
实操分享:看看小白我如何第一次搭建阿里云windows服务器(Tomcat+Mysql)
查看>>
Sphinx 配置文件说明
查看>>
数据结构实践——顺序表应用
查看>>
python2.7 之centos7 安装 pip, Scrapy
查看>>
机智云开源框架初始化顺序
查看>>
Spark修炼之道(进阶篇)——Spark入门到精通:第五节 Spark编程模型(二)
查看>>
一线架构师实践指南:云时代下双活零切换的七大关键点
查看>>
ART世界探险(19) - 优化编译器的编译流程
查看>>
玩转Edas应用部署
查看>>
music-音符与常用记号
查看>>