序言页码

简介: 序言页码

题目:

目描述

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

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;
} 
相关文章
|
缓存 自然语言处理 API
阿里云百炼产品月刊【2025年8月】
阿里云百炼平台8月推出多项更新与活动。通义千问系列重磅升级,新增多款图像、语音及研究模型,如Qwen-Image、Qwen-Image-Edit、Qwen-MT-Image、Wan2.2-S2V等,全面增强图文生成与编辑能力。推出Qwen-Flash轻量模型,优化代码与推理性能,支持高并发低延迟场景。平台服务稳定性提升,部分模型计费策略调整,上下文缓存价格降低至input_token的20%,并提供100万免费token额度。同步上线“实训Agent创客”活动,助力用户快速上手新模型,提升实践能力。
483 0
|
3月前
|
人工智能 分布式计算 PyTorch
Ray Forward 2025 定档 12 月 20 日北京!议题征集通道已开放
由蚂蚁集团发起的 Ray 中文社区与蚂蚁开源联合主办的 Ray Forward 2025,将于 12 月 20 日在北京蚂蚁 T 空间正式启幕,以 “拥抱 AI,Ray 向未来” 为主题,邀您共探下一代智能计算架构的进化方向。
|
3月前
|
存储 算法 数据库
从零到一构建你的第一个检索增强生成应用
本文将带你深入了解检索增强生成(RAG)技术的核心思想,解决大型语言模型(LLM)固有的知识局限和“幻觉”问题。我们将一步步拆解RAG的工作流程,从文档处理到向量检索,并提供一份基于Python的简易代码实现,助你快速上手,构建你的第一个RAG应用。
275 2
|
8月前
|
网络协议 中间件 网络安全
计算机网络OSI七层模型
OSI模型分为七层,各层功能明确:物理层传输比特流,数据链路层负责帧传输,网络层处理数据包路由,传输层确保端到端可靠传输,会话层管理会话,表示层负责数据格式转换与加密,应用层提供网络服务。数据在传输中经过封装与解封装过程。OSI模型优点包括标准化、模块化和互操作性,但也存在复杂性高、效率较低及实用性不足的问题,在实际中TCP/IP模型更常用。
1040 10
|
5月前
|
Web App开发 缓存 监控
有哪些常用的缓存清除工具?
有哪些常用的缓存清除工具?
614 0
|
8月前
|
监控 搜索推荐 UED
301重定向对SEO的影响:全面解析与最佳实践
本文深入探讨了301重定向在SEO中的作用,涵盖基本概念、积极影响(如保留链接权重、避免重复内容)、潜在风险(如权重传递不完全、错误实施)及最佳实践。同时对比了其他重定向类型,提供了技术实现建议和常见应用场景,帮助网站管理员正确使用301重定向以优化用户体验和搜索引擎表现。
384 16
|
人工智能 数据库
Poetry2Image:专为中文古诗词设计的图像生成校正框架,增强了诗歌内容与模型生成图像之间的一致性
Poetry2Image 是一个专为中文古诗词图像生成设计的迭代校正框架,通过自动化反馈和校正循环,提升诗歌与图像之间的一致性,有效捕捉诗歌的语义和艺术精髓。
435 11
Poetry2Image:专为中文古诗词设计的图像生成校正框架,增强了诗歌内容与模型生成图像之间的一致性
|
存储 监控 前端开发
如何确保测试脚本的稳定性和可靠性?
确保测试脚本的稳定性和可靠性是保证性能测试结果准确有效的关键
396 58
|
机器学习/深度学习 自然语言处理 算法
《Java 情感分析:前沿技术与方法全解析》
在数字化时代,情感分析是提取文本数据价值的关键技术。本文探讨了Java在这一领域的应用,涵盖自然语言处理工具(如Apache OpenNLP、Stanford NLP)、机器学习方法(如朴素贝叶斯、SVM)及深度学习框架(如TensorFlow、Deeplearning4j)。通过这些技术和工具,Java能够高效处理情感分析任务,广泛应用于社交媒体监测、客户反馈分析等场景,尽管仍面临文本多样性与复杂性的挑战。
424 9
|
算法 安全 物联网安全
物联网安全|位置隐私保护方法
物联网安全|位置隐私保护方法
1103 15
物联网安全|位置隐私保护方法