序言页码

简介: 序言页码

题目:

目描述

一类书的序言是以罗马数字标页码的。传统罗马数字用单个字母表示特定的数值,一下是标准数字表:

I 1 L 50 M 1000

V 5 C 100

X 10 D 500

最多3个可以表示为10n的数字(I,X,C,M)可以连续放在一起,表示它们的和:

III=3

CCC=300

可表示为5x10n的字符(V,L,D)从不连续出现。

除了下一个规则,一般来说,字符以递减的顺序接连出现:

CCLXVIII = 100+100+50+10+5+1+1+1 = 268

有时,一个可表示为10^n的数出现在一个比它大的数前(I在V或X前面,X在L或C前面,等等)。在这种情况下,数值等于后面的那个数减去前面的那个数:

IV = 4

IX = 9

XL = 40

像XD, IC, 和XM这样的表达是非法的,因为前面的数比后面的数小太多。对于XD(490的错误表达),可以写成 CDXC; 对于IC(99的错误表达),可以写成XCIX; 对于XM(990的错误表达),可以写成CMXC。

给定N(1 <= N < 3,500), 序言的页码数,请统计在第1页到第N也中,有几个I出现,几个V出现,等等 (从小到大的顺序)。不要输出并没有出现过的字符。

比如N = 5, 那么页码数为: I, II, III, IV, V. 总共有7个I出现,2个V出现。

输入

一个整数N。

输出

每行一个字符和一个数字k,表示这个字符出现了k次。字符必须按数字表中的递增顺序输出。

样例输入

5

样例输出

I 7

V 2

解题思路:这个题首先就是先把数字拆分成一位一位的,先列一个表:

   0    1     2    3     4     5    6    7    8     9
个 0    I    II    III   IV    V    VI   VII  VIII  Ix 
十 0    X    XX    XXX   XL    L    LX   LXX  LXXX  XC 
百 0    C    CC    CCC   CD    D    DC   DCC  DCCC  CM 
千 0    M    MM    MMM   0     0    0    0    0     0 

举一个列子:982=900+80+2就是:CM+LXXX+II;

然后判断该数的位数,观察上面的 数可以找出规律

发现一位二位三位的数的字母组成都一样,所以判断之后改变x的值就行了

程序代码:

#include<stdio.h>
#include<string.h>
#include<math.h>
char s[7]={'I','V','X','L','C','D','M'};
int a[10];
void fn(int n)
{
    int i,j,k,x,y,z,t;
    while(n)
    {
        k=log10(n)+1;
        if(k==1)
            x=1;
        else if(k==2)
            x=3;
        else if(k==3)
            x=5;
        y=x+1; z=x+2;
        t=n/(int)pow(10,k-1);
        if(t>=1&&t<=3)
            a[x]+=t;
        else if(t==4)
        {
            a[x]++;
            a[y]++;
        }
        else if(t==5)
            a[y]++;
        else if(t>=6&&t<=8)
        {
            a[y]++;
            a[x]+=t-5;
        }
        else if(t==9)
        {
            a[x]++;
            a[z]++;
             
        }
        n=n-t*pow(10,k-1);  
    }
}
int main()
{
    int i,j,k,m;
    while(scanf("%d",&m)!=EOF)
    {
        memset(a,0,sizeof(0));
        for(i=1;i<=m;i++)
        {   
            if(i>=1000)
            {
                a[7]+=i/1000;
                k=i%1000;
                fn(k);
            }
            else
                fn(i);  
        }   
        for(i=0;i<7;i++)
            if(a[i+1]!=0)
                printf("%c %d\n",s[i],a[i+1]);
    }
    return 0;
} 
相关文章
|
Java Shell Linux
Shell笔记(超级完整)
Shell笔记(超级完整)
Shell笔记(超级完整)
|
Linux
海思3559万能平台搭建:串口编程
海思3559万能平台搭建:串口编程
482 0
海思3559万能平台搭建:串口编程
|
存储 安全 应用服务中间件
谷粒学院(十六)OAuth2 | 微信扫码登录 | QQ扫码登录(一)
谷粒学院(十六)OAuth2 | 微信扫码登录 | QQ扫码登录(一)
谷粒学院(十六)OAuth2 | 微信扫码登录 | QQ扫码登录(一)
|
机器学习/深度学习 算法
【回溯与分支限界法】运动员最优匹配问题
【回溯与分支限界法】运动员最优匹配问题
737 0
【回溯与分支限界法】运动员最优匹配问题
阿里云账号个人实名认证和企业实名认证有何区别?企业实名有何优势?
本文介绍了阿里云个人实名认证账号与企业实名认证账号的区别以及选择企业实名认证有何优势。
1476 0
阿里云账号个人实名认证和企业实名认证有何区别?企业实名有何优势?
|
SQL 资源调度 分布式计算
Fuxi2.0—飞天大数据平台调度系统全面升级,首次亮相2019双十一
随着 Fuxi 2.0 首次亮相双十一,今年飞天大数据平台在混部侧支持和基线保障2个方面均顺利完成了目标。其中,混部支持了双十一 60%在线交易洪峰的流量,超大规模混部调度符合预期。在基线保障方面,单日数据处理 970PB,较去年增长超过60%。
3302 0
Fuxi2.0—飞天大数据平台调度系统全面升级,首次亮相2019双十一
|
弹性计算 监控 网络安全
阿里云发布固定公网IP升级为弹性公网IP功能
固定公网IP,弹性公网IP,为什么一个IP还有这么多类型? 到底应该选哪种类型的IP? 为什么小编推荐弹性公网IP,弹性公网IP有哪些黑科技? 本文带您一一探索和解密。
15314 1
|
算法 物联网 关系型数据库
数据库案例集锦 - 开发者的《如来神掌》
案例 1、《多字段,任意组合(0建模) - 毫秒级实时圈人 - 最佳实践》 2、《IoT(物联网)极限写入、消费 最佳实践 - 块级(ctid)扫描》 3、数据采样和脱敏实践 《PostgreSQL 数据采样与脱敏》 《PostgreSQL 巧妙的数据采样方法》 4、数据清洗和去重实践 .
17839 0
|
网络协议 Linux 搜索推荐
03中国开源镜像站点汇总
中国开源镜像站点汇总 阿里云 http://mirrors.aliyun.com/ 163安装软件镜像源 163开源镜像站是国内比较老的一个网站。
2057 1
|
前端开发 开发者 数据库
对比开源cms三巨头Joomla wordpress drupal哪个才是真正的王者
但凡接触过互联网的人,大都知道网页和博客,或许您也非常希望能有一个属于自己的网页或者博客。当前,也有各式各样的程序代码可以让你创建一个网站或者博客,我们现在更多的把他们称之为CMS(内容管理系统)。如果您在互联网上搜索一下,估计自己也会非常迷糊到底该采用哪种程序,在您开始之前,无妨一读下面的内容。

热门文章

最新文章