Preface Numbering序言页码
题面
(preface.pas/c/cpp)
一类书的序言是以罗马数字标页码的。传统罗马数字用单个字母表示特定的数值,以下是标准数字表:
I 1  V 5  X 10  L 50  C 100  D 500  M 1000
最多3个同样的可以表示为10n的数字(I,X,C,M)可以连续放在一起,表示它们的和:
III=3
CCC=300
可表示为5x10n的字符(V,L,D)从不连续出现。
除了下一个规则,一般来说,字符以递减的顺序接连出现:
CCLXVIII = 100+100+50+10+5+1+1+1 = 268
有时,一个可表示为10n的数出现在一个比它大1级或2级的数前(I在V或X前面,X在L或C前面,等等)。在这种情况下,数值等于后面的那个数减去前面的那个数:
IV = 4
IX = 9
XL = 40
一个数 用罗马数字来表示 有且仅有一种 而且不能复合嵌套使用(比如I是1 X是10 有人可能要说 IXL就能表示50-10-1 但是IXL绝对不能用来表达39 ) (那么39用什么来表示呢 XXXIX是唯一 而且正确的选择- -)
像XD, IC, 和XM这样的表达是非法的,因为前面的数比后面的数小太多。对于XD(490的错误表达),可以写成 CDXC; 对于IC(99的错误表达),可以写成XCIX; 对于XM(990的错误表达),可以写成CMXC。 90 写成 XC 而不是 LXL, 因为 L 后面的 X 意味着后继标记是 X 或者更小 (不管怎样,可能吧)(等同于阿拉伯数字 每位 数字分别表示)。
给定N(1 <= N < 3,500), 序言的页码数,请统计在第1页到第N页中,有几个I出现,几个V出现,等等 (从小到大的顺序)。不要输出没有出现过的字符。
比如N = 5, 那么页码数为: I, II, III, IV, V. 总共有7个I出现,2个V出现。
格式
PROGRAM NAME: preface
INPUT FORMAT:
(preface.in)
一个整数N。
OUTPUT FORMAT:
(preface.out)
每行一个字符和一个数字k,表示这个字符出现了k次。字符必须按数字表中的递增顺序输出。
SAMPLE INPUT
5
SAMPLE OUTPUT
I 7
V 2
分析:
本题其实是找规律题题目。首先我们把每个数字分解成每一位,探究发现,每一位至多有三个数字组成(具体字母见代码),记为a,b,c,设a<b<c,则十进制中:
- 1~3由a组成
- 4由1a1b组成
- 58本质与13相同,由a,b组成
- 9由1a1c组成
这样之后把统计的个数都记录在一个数组中,最后判断是否有再输出。
要注意:当前数字等于0时要包括在1~3中,否则必须严格卡住范围,不能最后只else
代码:
#include<cstdio>
#include<map>
using namespace std;
map<char,int>m;
char a,b,c;
void search(int x)
{
	int ans=0;
	while(x)
	{
		ans++;
		if(ans==1)
            a='I',b='V',c='X';//个位的组成
        else
		if(ans==2)
            a='X',b='L',c='C';//十位
        else
		if(ans==3)
            a='C',b='D',c='M';//百位
        else
            a='M';//千位及以上
        int dq=x%10;
        if(dq>=0&&dq<=3)m[a]+=dq;
        else
        if(dq==4)
        {
        	m[a]++;
        	m[b]++;
        }
        else
        if(dq>=5&&dq<=8)
        {
        	m[a]+=dq-5;
        	m[b]++;
        }
        else
        {
        	m[a]++;
        	m[c]++;
        }
        x=x/10;
	}
	return ;
}
int main()
{
	int n;
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	{
		search(i);
	}
	if(m['I'])
	printf("I %d\n",m['I']);
    if(m['V'])
	printf("V %d\n",m['V']);
    if(m['X'])
	printf("X %d\n",m['X']);
    if(m['L'])
	printf("L %d\n",m['L']);
    if(m['C'])
	printf("C %d\n",m['C']);
    if(m['D'])
	printf("D %d\n",m['D']);
    if(m['M'])
	printf("M %d\n",m['M']);
    return 0;
}
Preface Numbering序言页码的更多相关文章
- USACO 2.2 Preface Numbering
		Preface Numbering A certain book's prefaces are numbered in upper case Roman numerals. Traditional R ... 
- P1465 序言页码 Preface Numbering (手推)
		题目描述 一类书的序言是以罗马数字标页码的.传统罗马数字用单个字母表示特定的数值,以下是标准数字表: I 1 V 5 X 10 L 50 C 100 D 500 M 1000 最多3个同样的可以表示为 ... 
- 【USACO 2.2.1】序言页码
		[题目描述] 一类书的序言是以罗马数字标页码的.传统罗马数字用单个字母表示特定的数值,以下是标准数字表: I 1 L 50 M 1000 V 5 C 100 X 10 D 500 最多3个同样的可以表 ... 
- 【USACO 2.2】Preface Numbering (找规律)
		求 1-n 的所有罗马数字表达中,出现过的每个字母的个数. 分别对每个数的罗马表达式计算每个字母个数. 对于十进制的每一位,都是一样的规则,只是代表的字母不同. 于是我们从最后一位往前考虑,当前位由字 ... 
- USACO Section 2.2: Preface Numbering
		搬了leetcode的代码 /* ID: yingzho1 LANG: C++ TASK: preface */ #include <iostream> #include <fstr ... 
- USACO Preface Numbering 构造
		一开始看到这道题目的时候,感觉好难 还要算出罗马的规则. 但是仔细一看,数据规模很小, n 只给到3500 看完题目给出了几组样例之后就有感觉了 解题方法就是: n的每个十进制数 转换成相应的罗马数字 ... 
- USACO Section2.2 Preface Numbering 解题报告 【icedream61】
		preface解题报告----------------------------------------------------------------------------------------- ... 
- Preface Numbering
		链接 分析:先打表需要用到的罗马数字,然后暴力转换,最后统计一下即可 /* PROB:preface ID:wanghan LANG:C++ */ #include "iostream&qu ... 
- USACO2.2 Preface Numbering【思维+打表】
		这道题乍一看没有什么思路,细看还是没有什么思路 嗯,细看还是可以看出些什么端倪. 不能复合嵌套什么的 总结一下就只有这样3种规则: 1.IXCM最多三个同样连续 加起来2.递减:加起来 注意VLD不连 ... 
随机推荐
- 【Windows10 IoT开发系列】“Hello,World!”指导
			原文:[Windows10 IoT开发系列]"Hello,World!"指导 本文主要是介绍使用C#来开发一个可以运行在Raspberry Pi2上的一个基本项目. 1.在启动V ... 
- 网易Lofter
			作为老网虫,对网易的感情是很深的.当我知道Lofter这个东西后,曾经很兴奋要好好打理自己的博客,然而兴奋很快过了.因为Lofter无时无刻不在刷存在感.无限空间加无限图片流量,国内的服务无法做的更好 ... 
- Qt使用windows API获取程序运行时占用内存 good
			使用的是psapi.h中的GetProcessMemoryInfo函数,但是运行到该函数时就强制退出了. 后来,百度到原因是 原来Qt编译时加了-mthread,createprocess时要使的Ha ... 
- CTO的职责,以及Goolge内部流程
			我先做一下自我介绍,我是 2007 年加入的 Google,在 Moutain View 总部任 Google SRE,今年年初回国加入 Coding. 在 Google 我参与了两个 Project ... 
- python列表的内建函数
			list.append(obj) 向列表中添加一个对象obj list.count(obj) 返回一个对象obj 在列表中出现的次数 list.extend(seq)a 把序列seq 的内容添加到列表 ... 
- 细谈unity资源加载和卸载
			转载请标明出处:http://www.cnblogs.com/zblade/ 一.概要 在了解unity的资源管理方式之后,接下来细谈一下Unity的资源是如何从磁盘中加载到运行时的内存中,以及又是如 ... 
- mogodbshell中数组对象查询修改方法
			在mongodb中,存在如下数据 { "_id" : ObjectId("59af55078a8fc5e51ff425de"), "title&quo ... 
- Laravel --- 自动生成数据
			1.创建填充文件:php artisan make:seeder UserTableSeeder 2.在run方法里面写填充数据的代码: use Illuminate\Database\Seeder; ... 
- UI-grid 表格内容可编辑(enableCellEdit可指定列编辑)
			在网上搜索了很多关于UI-Grid的问题 很遗憾好少啊啊啊 不过有API还是比较欣慰的 官方API:UI Grid 还有一位大佬的翻译的中文API:angularjs ui-grid中文api 行编辑 ... 
- 微服务SpringCloud之服务调用与负载均衡
			上一篇我们学习了服务的注册与发现,本篇博客是在上一篇的基础上学习服务的调用.上一博客主要创建了Eureka的服务端和一个Client,该Client包含了一个Controller用来提供对外服务供外部 ... 
